This repository will offer several learning strategies and advanced study material along with the interesting Python code that will help jump start your journey of becoming a rockstar Python programmer!
- Sequence and it's operation
- What is Sequences
- Type of Sequence
- Sequence Operations
 
- Functions and Variables
- Built-in-Functions
- Lambda Function
- User Define Function
 
- Object Oriented Progrmaming (OOPs) Key Concepts
- Classes and Objects
- OOPs Features
 
- Standard Libraries
- Built-in-Function
- Modules
- Packages
 
- Numpy
- Pandas
- Matplotlib (Data Visualization)
- Data Manipulation
- Web Mapping
- Web Scrapping
- Computer Vision
- Regular Expression (RegEx)
A sequence is a succession of values bound together by a container that reflects their type. In other words, Sequences are containers with the items or elements that are accessible by indexing or slicing.
Almost every stream that you put in Python is a sequence. The sequence is central to programming and central to Python.
- 1. List
- 2. Tuples
- 3. Xrange
- 4. Strings
- Concatenation
- Repetation
- Membership Testing
- Slicing
- Indexing
- Reversing
List is a collection datatype in python. It is ordered and allows duplicate entries as well. Lists in python need not be homogeneous, which means it can contain different data types like integers, strings and other collection data types.
It is mutable in nature and allows indexing to access the members in a list. Also, the values can be changed even after a list is declared.
- A list is a sort of container that holds a number of other objects, in a given order.
- The list type implements the sequence protocol, and it also allows you to add and remove objects from the sequence.
- It is an ordered set of elements enclosed in square brackets.
Simple definition of list – li = []
li = list() # empty list li = list(sequence) li = list(expression for variable in sequence)
To access the elements of a list:
n = len(li)
item = li[index] #Indexing
slice = li[start:stop] #Slicing
While choosing a data type for storing our data, we must keep in mind the properties and features of the data type. It becomes more efficient and secure if we make the right choice in first place.
A list is preferred because it can store multiple data at the same time. It becomes easy to replace and modify the values inside a list. We can store the sequence in a list and perform several iterations using the loops as well. There are numerous operations we can perform on a list as well, lets understand the various operations that we have for lists in python.
Following are the operations that we can perform on a list.
- append
- clear
- copy
- count
- extend
- insert
- index
- pop
- remove
- reverse
- sort
Tuple is a collection which is unchangeable or immutable. It is ordered and the values can be accessed using the index values. A tuple can have duplicate values as well. To declare a tuple we use the round brackets.
Range is a data type which is mainly used when we are using a loop.
Range() generates lists containing arithmetic progression.
There are three variations of range() function:
range(stop) – Starts from 0 till (stop – 1)
range(start,stop) – Ends at (stop – 1)
range(start,stop,step) – Step cannot be 0, default is 1
If the range is defined as 5, it will simply show the list of numbers falling in the range from 0 to 5. It starts by default from 0 and stops before 5, as defined.
In this, point of starting as well as stopping is defined. As shown in the example below, the start range has been defined as 5, while stop range as 10. Hence, it will display the numbers 5, 6, 7, 8, 9, which range between 5 to 10.
The first two values defined here are the same, start and stop, while the third one is step, which means the difference between every two consecutive numbers. For example, if range is defined in this way: range(0, 10, 2). It will give away numbers between 0 to 10, but with a difference of 2, in this way: [0, 2, 4, 6, 8]. The step here cannot be given 0 value. It has to be 1 or greater than 1.
Strings in python are used to represent unicode character values. Python does not have a character data type, a single character is also considered as a string.
We denote or declare the string values inside single quotes or double quotes. To access the values in a string, we use the indexes and square brackets.
Strings are immutable in nature, which means you cannot change a string once replaced.
In Python, A function is a block of organized, reusable code that is used to perform single and related action. It is only runs when it is called.
You can pass data, known as parameters, into a function.
A function can return data as a result.
Return Statement : The return statement terminates the execution of function and returns control to the calling function
To define a Python function, you’d have to use the ‘def’ keyword before the name of your function and add parentheses to its end, followed by a colon(:).
Python uses indentation to indicate blocks instead of brackets to make codes more readable.
The "rules" for naming a function are the same as naming a variable. It begins with either letter from A-Z, a-z in both upper & lower cases or an underscore(). The rest of its name can contain underscores(), digits(0-9), any letters in upper or lower case.
A reserved keyword may not be chosen as an identifier. Good usage of grammar to ensure enhanced readability of code. It is good practice to name a Python function according to what it does. use a docstring right under the first line of a function declaration. This is a documentation string, and it explains what the function does.
There are many types of Python Functions. And each of them is very vital in its own way. The following are the different types of Python Functions:
The Python interpreter has a number of functions that are always available for use. These functions are called built-in functions. For example, print() function prints the given object to the standard output device (screen) or to the text stream file.
In Python 3.6, there are 68 built-in functions. But for the sake of simplicity let us consider the majorly used functions and we can build on from there.
Definition : The abs() method returns the absolute value of the given number. If the number is a complex number, abs() returns its magnitude.
The all() method returns True when all elements in the given iterable are true. If not, it returns False.
The syntax of all() method is:
all(iterable)
The all() method takes a single parameter:
iterable – Any iterable (list, tuple, dictionary, etc.) which contains the elements
The ascii() method returns a string containing a printable representation of an object. It escapes the non-ASCII characters in the string using x, u or U escapes.
The syntax of ascii() method is:
ascii(object)
The ascii() method takes an object (like strings, list etc).
The bin() method converts and returns the binary equivalent string of a given integer. If the parameter isn’t an integer, it has to implement index() method to return an integer.
The syntax of bin() method is:
bin(num)
The bin() method takes a single parameter:
num – an integer number whose binary equivalent is to be calculated. If not an integer, should implement index() method to return an integer.
The bool() method converts and returns the binary equivalent string of a given integer. If the parameter isn’t an integer, it has to implement index() method to return an integer.
The syntax of bool() method is:
bool([value])
It’s not mandatory to pass a value to bool(). If you do not pass a value, bool() returns False.
In general use, bool() takes a single parameter value.
The compile() method returns a Python code object from the source (normal string, a byte string, or an AST object).
The syntax of compile() method is:
compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1)
- source – a normal string, a byte string, or an AST object
- filename – file from which the code was read. If it wasn’t read from a file, you can give a name yourself
- mode – Either exec or eval or single. - eval – accepts only a single expression. - exec – It can take a code block that has Python statements, class and functions and so on. - single – if it consists of a single interactive statement
- flags (optional) and dont_inherit (optional) – controls which future statements affect the compilation of the source. Default Value: 0
- optimize (optional) – optimization level of the compiler. Default value -1.
The dict() constructor creates a dictionary in Python.
Different forms of dict() constructors are:
- class dict(**kwarg)
- class dict(mapping, **kwarg)
- class dict(iterable, **kwarg)
The enumerate() method adds counter to an iterable and returns it (the enumerate object).
The syntax of enumerate() method is:
enumerate(iterable, start=0)
The enumerate() method takes two parameters:
- iterable – a sequence, an iterator, or objects that support iteration
- start (optional) – enumerate() starts counting from this number. If start is omitted, 0 is taken as the start.
The eval() method parses the expression passed to this method and runs python expression (code) within the program.
The syntax of eval() method is:
eval(expression, globals=None, locals=None)
The eval() takes three parameters:
- expression – this string is parsed and evaluated as a Python expression
- globals (optional) – a dictionary
- locals (optional)- a mapping object. Dictionary is the standard and commonly used mapping type in Python.
The filter() method constructs an iterator from elements of an iterable for which a function returns true.
The syntax of filter() method is:
filter(function, iterable)
The filter() method takes two parameters:
- function – function that tests if elements of an iterable return true or false If None, the function defaults to Identity function – which returns false if any elements are false
- iterable – iterable which is to be filtered, could be sets, lists, tuples, or containers of any iterators
The getattr() method returns the value of the named attribute of an object. If not found, it returns the default value provided to the function.
The syntax of getattr() method is:
getattr(object, name[, default])
The getattr() method takes multiple parameters:
- object – object whose named attribute’s value is to be returned
- name – string that contains the attribute’s name
- default (Optional) – value that is returned when the named attribute is not foun
The help() method calls the built-in Python help system.
The syntax of help() method is:
help(object)
The help() method takes the maximum of one parameter.
- object (optional) – you want to generate the help of the given object
The id() function returns identity (unique integer) of an object.
The syntax of id() method is:
id(object)
The id() function takes a single parameter object.
The len() function returns the number of items (length) in an object.
The syntax of len() method is:
len(s)
s – a sequence (string, bytes, tuple, list, or range) or a collection (dictionary, set or frozen set)
The max() method returns the largest element in an iterable or largest of two or more parameters.
The syntax of max() method is:
max(iterable, *iterables[,key, default])
max(arg1, arg2, *args[, key])
max() has two forms of arguments it can work with.
- 
max(iterable, *iterables[, key, default]) - iterable – sequence (tuple, string), collection (set, dictionary) or an iterator object whose largest element is to be found - *iterables (Optional) – any number of iterables whose largest is to be found - key (Optional) – key function where the iterables are passed and the comparison is performed based on its return value - default (Optional) – default value if the given iterable is empty 
- 
max(arg1, arg2, *args[, key]) - arg1 – mandatory first object for comparison (could be number, string or other object) - arg2 – mandatory second object for comparison (could be number, string or another object) - *args (Optional) – other objects for comparison - key – key function where each argument is passed and the comparison is performed based on its return value 
The min() method returns the smallest element in an iterable or smallest of two or more parameters.
min(iterable, *iterables[,key, default]) min(arg1, arg2, *args[, key])
min() has two forms of arguments it can work with.
- min(iterable, *iterables[, key, default]) - iterable – sequence (tuple, string), collection (set, dictionary) or an iterator object whose smallest element is to be found - *iterables (Optional) – any number of iterables whose smallest is to be found - key (Optional) – key function where the iterables are passed and the comparison is performed based on its return value - default (Optional) – default value if the given iterable is empty
- min(arg1, arg2, *args[, key]) - arg1 – mandatory first object for comparison (could be number, string or other object) - arg2 – mandatory second object for comparison (could be number, string or other object) - *args (Optional) – other objects for comparison - key – key function where each argument is passed and a comparison is performed based on its return value
The oct() method takes an integer number and returns its octal representation. If the given number is an int, it must implement index() method to return an integer.
oct(x)
The oct() method takes a single parameter x.
This parameter could be:
- an integer number (binary, decimal or hexadecimal)
- if not an integer, must implement index() method to return an integer
The pow() method returns x to the power of y. If the third argument (z) is given, it returns x to the power of y modulus z, i.e. pow(x, y) % z.
pow(x, y[, z])
The pow() method takes three parameters:
- x – number which is to be powered
- y – number which is to be powered with x
- z (Optional) – number which is to be used for modulus operation
The reversed() method returns the reversed iterator of the given sequence.
reversed(seq)
The reversed() method takes a single parameter:
- seq – sequence that should be reversed
Could be an object that supports sequence protocol (len() and getitem() methods) as tuple, string, list or range
Could be an object that has implemented reversed()
The sum() method returns the reversed iterator of the given sequence.
sum(iterable, start)
- iterable – iterable (list, tuple, dict etc) whose item’s sum is to be found. Normally, items of the iterable should be numbers.
- start (optional) – this value is added to the sum of items of the iterable. The default value of start is 0 (if omitted)
If a single argument (object) is passed to type() built-in, it returns the type of the given object. If three arguments (name, bases, and dict) are passed, it returns a new type object.
- type(object)
- type(name, bases, dict)
If the single object argument is passed to type(), it returns the type of the given object.
Recursion is the process of defining something in terms of itself.
A physical world example would be to place two parallel mirrors facing each other. Any object in between them would be reflected recursively.
We know that in Python, a function can call other functions. It is even possible for the function to call itself. These type of construct are termed as recursive functions.
Following is an example of a recursive function to find the factorial of an integer.
Factorial of a number is the product of all the integers from 1 to that number. For example, the factorial of 5 (denoted as 5!) is 12345 = 120.
In Python, an anonymous function is a function that is defined without a name.
While normal functions are defined using the def keyword, in Python anonymous functions are defined using the lambda keyword.
Hence, anonymous functions are also called lambda functions.
A Lambda function in python has the following syntax:
lambda arguments: expression
Lambda functions can have any number of arguments but only one expression. The expression is evaluated and returned. Lambda functions can be used wherever function objects are required.
Functions that we define ourselves to do the certain specific task are referred to as user-defined functions. The way in which we define and call functions in Python are already discussed.
Functions that readily come with Python are called built-in functions. If we use functions written by others in the form of the library, it can be termed as library functions.
All the other functions that we write on our own fall under user-defined functions. So, our user-defined function could be a library function to someone else.
- 
Python is an object oriented programming language. 
- 
Almost everything in Python is an object, with its properties and methods. 
- 
A Class is like an object constructor, or a "blueprint" for creating objects. 
The attributes are data members (class variables and instance variables) and methods which are accessed via dot notation.
- Class variable is a variable that is shared by all the different objects/instances of a class.
- Instance variables are variables which are unique to each instance. It is defined inside a method and belongs only to the current instance of a class.
- Methods are also called as functions which are defined in a class and describes the behaviour of an object.
Consider a module to be the same as a code library. A file containing a set of functions you want to include in your application.
Modules are simply a ‘program logic’ or a ‘python script’ that can be used for variety of applications or functions. We can declare functions, classes etc in a module.
The focus is to break down the code into different modules so that there will be no or minimum dependencies on one another. Using modules in a code helps to write lesser line of codes, a single procedure developed for reuse of the code as well. It also eliminates the need to write the same logic again and again.
One more advantage of using modules is that the programs can be designed easily, since a whole team works only on a part or module of the entire code.
When we import a module, the interpreter looks for the module in the build-in modules directories in sys.path and if not found, it will look for the module in the following order:
- Current directory
- PYTHONPATH
- Default directory
Built-in modules are written in C and integrated with python interpreter. Each built-in module contains resources for certain specific functionalities like Operating system management, disk input/output etc.
The standard library also has many python scripts containing useful utilities. There are several built-in modules in python at our disposal that we can use whenever we want.
Some Important Built-in-Modules are:
- Sys
- Os
- Math
- DateTime
- Random
- Json
NumPy is the package of scientific computing
NumPy is the fundamental package for scientific computing with Python. It contains among other things:
- a powerful N-dimensional array (Ndarray) object
- sophisticated (broadcasting) functions
- tools for integrating C/C++ and Fortran code
- useful linear algebra, Fourier transform, and random number capabilities
Besides its obvious scientific uses, NumPy can also be used as an efficient multi-dimensional container of generic data. Arbitrary data-types can be defined. This allows NumPy to seamlessly and speedily integrate with a wide variety of databases.
NumPy is licensed under the BSD license, enabling reuse with few restrictions.
NumPy’s main object is the homogeneous multidimensional array. It is a table of elements (usually numbers), all of the same type, indexed by a tuple of positive integers. In NumPy dimensions are called axes.
NumPy’s array class is called ndarray. It is also known by the alias array.
The Ndarray is a multi-dimenstional array object consisting of two parts -- the actual data, some metadata which describes the stored data. They are indexed just like sequence are in python, starting from 0.
- Each element of Ndarray is an object of data-type object (called dtype)
- An item extracted form ndarray, is represented by a python object of an array scaler type
- 
ndarray.ndim : the number of axes (dimensions) of the array. 
- 
ndarray.shape : the dimensions of the array. This is a tuple of integers indicating the size of the array in each dimension. For a matrix with n rows and m columns, shape will be (n,m). The length of the shape tuple is therefore the number of axes, ndim. 
- 
ndarray.size : the total number of elements of the array. This is equal to the product of the elements of shape. 
- 
ndarray.dtype : an object describing the type of the elements in the array. One can create or specify dtype’s using standard Python types. Additionally NumPy provides types of its own. numpy.int32, numpy.int16, and numpy.float64 are some examples. 
- 
ndarray.itemsize : the size in bytes of each element of the array. For example, an array of elements of type float64 has itemsize 8 (=64/8), while one of type complex32 has itemsize 4 (=32/8). It is equivalent to ndarray.dtype.itemsize. 
- 
ndarray.data : the buffer containing the actual elements of the array. Normally, we won’t need to use this attribute because we will access the elements in an array using indexing facilities. 
pandas is an open source, Python Data Analysis Library providing high-performance, easy-to-use data structures and data analysis tools for the Python programming language.
The name Pandas is drived from "Panel Data" - an Econometrics from Multidimensional data.
- A fast and efficient DataFrame object for data manipulation with integrated indexing;
- Tools for reading and writing data between in-memory data structures and different formats: CSV and text files, Microsoft Excel, SQL databases, and the fast HDF5 format;
- Intelligent data alignment and integrated handling of missing data: gain automatic label-based alignment in computations and easily manipulate messy data into an orderly form;
- Flexible reshaping and pivoting of data sets;
- Intelligent label-based slicing, fancy indexing, and subsetting of large data sets;
- Columns can be inserted and deleted from data structures for size mutability;
- Aggregating or transforming data with a powerful group by engine allowing split-apply-combine operations on data sets;
- High performance merging and joining of data sets;
- Hierarchical axis indexing provides an intuitive way of working with high-dimensional data in a lower-dimensional data structure;
- Time series-functionality: date range generation and frequency conversion, moving window statistics, moving window linear regressions, date shifting and lagging. Even create domain-specific time offsets and join time series without losing data;
- Highly optimized for performance, with critical code paths written in Cython or C.
- Python with pandas is in use in a wide variety of academic and commercial domains, including Finance, Neuroscience, Economics, Statistics, Advertising, Web Analytics, and more.
- Tabular data with hetrogeneously-typed columns.
- Ordered and unordered time series data.
- Arbitary matrix data with row and column lebels
- Any other form of observational/Statistical data set. The data actually need not be labeled all to be placed into Pandas data structure.
Pandas provides three data structures: Series, Data Frame and Panel; all of which are built on top of the NumPy array.
Matplotlib is a Python library this is specially desigend for the development of graphs, charts etc., in order to provide interactive data visualization.
Matplotlib is a Python 2D plotting library which produces publication quality figures in a variety of hardcopy formats and interactive environments across platforms.
Matplotlib tries to make easy things easy and hard things possible. You can generate plots, histograms, power spectra, bar charts, errorcharts, scatterplots, etc., with just a few lines of code.
Matplotlib is inspried form the MATLAB software and reproduces many of it's feature
Example: Lets plot simple graph on matplotlib
magine you have to pull a large amount of data from websites and you want to do it as quickly as possible. How would you do it without manually going to each website and getting the data? Well, “Web Scraping” is the answer. Web Scraping just makes this job easier and faster.
Web scraping is used to collect large information from websites. But why does someone have to collect such large data from websites? To know about this, let’s look at the applications of web scraping:
Services such as ParseHub use web scraping to collect data from online shopping websites and use it to compare the prices of products.
Many companies that use email as a medium for marketing, use web scraping to collect email ID and then send bulk emails.
Web scraping is used to collect data from Social Media websites such as Twitter to find out what’s trending.
Web scraping is used to collect a large set of data (Statistics, General Information, Temperature, etc.) from websites, which are analyzed and used to carry out Surveys or for R&D.
Details regarding job openings, interviews are collected from different websites and then listed in one place so that it is easily accessible to the user.
Web scraping is an automated method used to extract large amounts of data from websites. The data on the websites are unstructured. Web scraping helps collect these unstructured data and store it in a structured form. There are different ways to scrape websites such as online Services, APIs or writing your own code. In this article, we’ll see how to implement web scraping with python.
When you run the code for web scraping, a request is sent to the URL that you have mentioned. As a response to the request, the server sends the data and allows you to read the HTML or XML page. The code then, parses the HTML or XML page, finds the data and extracts it.
To extract data using web scraping with python, you need to follow these basic steps:
As we know, Python is used for various applications and there are different libraries for different purposes. In our further demonstration, we will be using the following libraries:
Selenium is a web testing library. It is used to automate browser activities.
Beautiful Soup is a Python package for parsing HTML and XML documents. It creates parse trees that is helpful to extract the data easily.
Pandas is a library used for data manipulation and analysis. It is used to extract the data and store it in the desired format.
A RegEx, or Regular Expression, is a sequence of characters that forms a search pattern.
RegEx can be used to check if a string contains the specified search pattern.
RegEx Module
Python has a built-in package called re, which can be used to work with Regular Expressions.
Import the re module: import re