Advanced Python
Python Modules
- Importance of modular programming
- What is module
- Types of Modules – Pre defined, User defined.
- User defined modules creation
- Functions based modules
- Class based modules
- Connecting modules
- Import module
- From … import
- Module alias / Renaming module
- Built In properties of module
Packages
- Organizing python project into packages
- Types of packages – pre defined, user defined.
- Package v/s Folder
- py file
- Importing package
- PIP
- Introduction to PIP
- Installing PIP
- Installing Python packages
- Un installing Python packages
OOPs
- Procedural v/s Object oriented programming
- Principles of OOP – Encapsulation , Abstraction (Data Hiding)
- Classes and Objects
- How to define class in python
- Types of variables – instance variables, class variables.
- Types of methods – instance methods, class method, static method
- Object initialization
- ‘self’ reference variable
- ‘cls’ reference variable
- Access modifiers – private(__) , protected(_), public
- AT property class
- Property() object
- Creating object properties using setaltr, getaltr functions
- Encapsulation(Data Binding)
- What is polymorphism?
- Overriding
- i) Method overriding
- ii) Constructor overriding
- Overloading
- i) Method Overloading
- ii) Constructor Overloading
iii) Operator Overloading
- Class re-usability
- Composition
- Aggregation
- Inheritance – single , multi level, multiple, hierarchical and hybrid inheritance and Diamond inheritance
- Constructors in inheritance
- Object class
- super()
- Runtime polymorphism
- Method overriding
- Method resolution order(MRO)
- Method overriding in Multiple inheritance and Hybrid Inheritance
- Duck typing
- Concrete Methods in Abstract Base Classes
- Difference between Abstraction & Encapsulation
- Inner classes
- Introduction
- Writing inner class
- Accessing class level members of inner class
- Accessing object level members of inner class
- Local inner classes
- Complex inner classes
- Case studies
Exception Handling & Types of Errors
- What is Exception?
- Why exception handling?
- Syntax error v/s Runtime error
- Exception codes – AttributeError, ValueError, IndexError, TypeError…
- Handling exception – try except block
- Try with multi except
- Handling multiple exceptions with single except block
- Finally block
- Try-except-finally
- Try with finally
- Case study of finally block
- Raise keyword
- Custom exceptions / User defined exceptions
- Need to Custom exceptions
- Case studies
Regular expressions
- Understanding regular expressions
- String v/s Regular expression string
- “re” module functions
- Match()
- Search()
- Split()
- Findall()
- Compile()
- Sub()
- Subn()
- Expressions using operators and symbols
- Simple character matches
- Special characters
- Character classes
- Mobile number extraction
- Mail extraction
- Different Mail ID patterns
- Data extraction
- Password extraction
- URL extraction
- Vehicle number extraction
- Case study
File &Directory handling
- Introduction to files
- Opening file
- File modes
- Reading data from file
- Writing data into file
- Appending data into file
- Line count in File
- CSV module
- Creating CSV file
- Reading from CSV file
- Writing into CSV file
- Object serialization – pickle module
- XML parsing
- JSON parsing
Python Logging
- Logging Levels
- implement Logging
- Configure Log File in over writing Mode
- Timestamp in the Log Messages
- Python Program Exceptions to the Log File
- Requirement of Our Own Customized Logger
- Features of Customized Logger
Date & Time module
- How to use Date & Date Time class
- How to use Time Delta object
- Formatting Date and Time
- Calendar module
- Text calendar
- HTML calendar
OS module
- Shell script commands
- Various OS operations in Python
- Python file system shell methods
- Creating files and directories
- Removing files and directories
- Shutdown and Restart system
- Renaming files and directories
- Executing system commands
Multi-threading & Multi Processing
- Introduction
- Multi tasking v/s Multi threading
- Threading module
- Creating thread – inheriting Thread class , Using callable object
- Life cycle of thread
- Single threaded application
- Multi threaded application
- Can we call run() directly?
- Need to start() method
- Sleep()
- Join()
- Synchronization – Lock class – acquire(), release() functions
- Case studies
Garbage collection
- Introduction
- Importance of Manual garbage collection
- Self reference objects garbage collection
- ‘gc’ module
- Collect() method
- Threshold function
- Case studies
Python Data Base Communications(PDBC)
- Introduction to DBMS applications
- File system v/s DBMS
- Communicating with MySQL
- Python – MySQL connector
- connector module
- connect() method
- Oracle Database
- Install cx_Oracle
- Cursor Object methods
- execute() method
- executeMany() method
- fetchone()
- fetchmany()
- fetchall()
- Static queries v/s Dynamic queries
- Transaction management
- Case studies
Python – Network Programming
- What is Sockets?
- What is Socket Programming?
- The socket Module
- Server Socket Methods
- Connecting to a server
- A simple server-client program
- Server
- Client
Tkinter & Turtle
- Introduction to GUI programming
- Tkinter module
- Tk class
- Components / Widgets
- Label , Entry , Button , Combo, Radio
- Types of Layouts
- Handling events
- Widgets properties
- Case studies
Data analytics modules
- Numpy
- Introduction
- Scipy
- Introduction
- Arrays
- Datatypes
- Matrices
- N dimension arrays
- Indexing and Slicing
- Pandas
- Introduction
- Data Frames
- Merge , Join, Concat
- MatPlotLib introduction
- Drawing plots
- Introduction to Machine learning
- Types of Machine Learning?
- Introduction to Data science
DJANGO
- Introduction to PYTHON Django
- What is Web framework?
- Why Frameworks?
- Define MVT Design Pattern
- Difference between MVC and MVT
PANDAS
Pandas – Introduction
Pandas – Environment Setup
Pandas – Introduction to Data Structures
- Dimension & Description
- Series
- DataFrame
- Data Type of Columns
- Panel
Pandas — Series
- Series
- Create an Empty Series
- Create a Series f
- rom ndarray
- rom dict
- rom Scalar
- Accessing Data from Series with Position
- Retrieve Data Using Label (Index)
Pandas – DataFrame
- DataFrame
- Create DataFrame
- Create an Empty DataFrame
- Create a DataFrame from Lists
- Create a DataFrame from Dict of ndarrays / Lists
- Create a DataFrame from List of Dicts
- Create a DataFrame from Dict of Series
- Column Selection
- Column Addition
- Column Deletion
- Row Selection, Addition, and Deletion
Pandas – Panel
- Panel()
- Create Panel
- Selecting the Data from Panel
Pandas – Basic Functionality
- DataFrame Basic Functionality
Pandas – Descriptive Statistics
- Functions & Description
- Summarizing Data
Pandas – Function Application
- Table-wise Function Application
- Row or Column Wise Function Application
- Element Wise Function Application
Pandas – Reindexing
- Reindex to Align with Other Objects
- Filling while ReIndexing
- Limits on Filling while Reindexing
- Renaming
Pandas – Iteration
- Iterating a DataFrame
- iteritems()
- iterrows()
- itertuples()
Pandas – Sorting
- By Label
- Sorting Algorithm
Pandas – Working with Text Data
Pandas – Options and Customization
- get_option(param)
- set_option(param,value)
- reset_option(param)
- describe_option(param)
- option_context()
Pandas – Indexing and Selecting Data
- .loc()
- .iloc()
- .ix()
- Use of Notations
Pandas – Statistical Functions
- Percent_change
- Covariance
- Correlation
- Data Ranking
Pandas – Window Functions
- .rolling() Function
- .expanding() Function
- .ewm() Function
Pandas – Aggregations
- Applying Aggregations on DataFrame
Pandas – Missing Data
- Cleaning / Filling Missing Data
- Replace NaN with a Scalar Value
- Fill NA Forward and Backward
- Drop Missing Values
- Replace Missing (or) Generic Values
Pandas – GroupBy
- Split Data into Groups
- View Groups
- Iterating through Groups
- Select a Group
- Aggregations
- Transformations
- Filtration
Pandas – Merging/Joining
- Merge Using ‘how’ Argument
Pandas – Concatenation
- Concatenating Objects
- Time Series
Pandas – Date Functionality
Pandas – Timedelta
Pandas – Categorical Data
- Object Creation
Pandas – Visualization
- Bar Plot
- Histograms
- Box Plots
- Area Plot
- Scatter Plot
- Pie Chart
Pandas – IO Tools
- csv
Pandas – Sparse Data
Pandas – Caveats & Gotchas
Pandas – Comparison with SQL
NUMPY
NUMPY − INTRODUCTION
NUMPY − ENVIRONMENT
NUMPY − NDARRAY OBJECT
NUMPY − DATA TYPES
- Data Type Objects (dtype)
NUMPY − ARRAY ATTRIBUTES
- shape
- ndim
- itemsize
- flags
NUMPY − ARRAY CREATION ROUTINES
- empty
- zeros
- ones
NUMPY − ARRAY FROM EXISTING DATA
- asarray
- frombuffer
- fromiter
NUMPY − ARRAY FROM NUMERICAL RANGES
- arange
- linspace
- logspace
NUMPY − INDEXING & SLICING
NUMPY − ADVANCED INDEXING
- Integer Indexing
- Boolean Array Indexing
NUMPY − BROADCASTING
NUMPY − ITERATING OVER ARRAY
- Iteration
- Order
- Modifying Array Values
- External Loop
- Broadcasting Iteration
NUMPY – ARRAY MANIPULATION
- reshape
- ndarray.flat
- ndarray.flatten
- ravel
- transpose
- ndarray.T
- swapaxes
- rollaxis
- broadcast
- broadcast_to
- expand_dims
- squeeze
- concatenate
- stack
- hstack and numpy.vstack
- split
- hsplit and numpy.vsplit
- resize
- append
- insert
- delete
- unique
NUMPY – BINARY OPERATORS
- bitwise_and
- bitwise_or
- invert()
- left_shift
- right_shift
NUMPY − STRING FUNCTIONS
NUMPY − MATHEMATICAL FUNCTIONS
- Trigonometric Functions
- Functions for Rounding
NUMPY − ARITHMETIC OPERATIONS
- reciprocal()
- power()
- mod()
NUMPY − STATISTICAL FUNCTIONS
- amin() and numpy.amax()
- ptp()
- percentile()
- median()
- mean()
- average()
- Standard Deviation
- Variance
NUMPY − SORT, SEARCH & COUNTING FUNCTIONS
- sort()
- argsort()
- lexsort()
- argmax() and numpy.argmin()
- nonzero()
- where()
- extract()
NUMPY − BYTE SWAPPING
- ndarray.byteswap()
NUMPY − COPIES & VIEWS
- No Copy
- View or Shallow Copy
- Deep Copy
NUMPY − MATRIX LIBRARY
- empty()
- matlib.zeros()
- matlib.ones()
- matlib.eye()
- matlib.identity()
- matlib.rand()
NUMPY − LINEAR ALGEBRA
- dot()
- vdot()
- inner()
- matmul()
- Determinant
- linalg.solve()
NUMPY − MATPLOTLIB
- Sine Wave Plot
- subplot()
- bar()
NUMPY – HISTOGRAM USING MATPLOTLIB
- histogram()
- plt()
NUMPY − I/O WITH NUMPY
- save()
- savetxt()