Python
What is it?
-
Python is a programming language.
-
It is an interpreted language which executes line by line.
-
It is used for web development (server-side), software development, mathematics, system scripting.
-
Used on a server to create web applications and can connect to database systems.
-
It can also read and modify files.
data:image/s3,"s3://crabby-images/c64fe/c64fea49d8fc1fc156fb5b7453d2c192ed2fb71d" alt=""
History
-
It was created in 1991.
-
Designed by Guido van Rossum. (worked in Google & Dropbox)
Uses
-
Automatic Task
-
Make a game
-
Real-world problems
-
Server-client web development.
-
General purpose software.
-
Embedded software.
Why
-
Python was designed to for readability.
-
Python works on different platforms.
-
Python can be treated in a procedural way, an object-orientated way or a functional way.
-
One line code for swapping values; x,y = y,x
Cross-compilers to other languages
-
There are several compilers to run the python program on different platforms.
-
Here are some examples:
-
Jython compiles into Java bytecode, and execute on Java Virtual Machine.
-
IronPython is to run Python programs on the .NET Common Language Runtime.
-
Pyjs compiles Python to JavaScript.
-
Cython compiles Python to C and C++.
Python Installation
-
To check if you have python installed on a Windows PC:
-
Run the following on the Command Line (cmd.exe), python --version
data:image/s3,"s3://crabby-images/1114f/1114f38db8f62e8d9d32e9a442f68528edbd372d" alt=""
There is no Python installed on the PC.
Type python - -version
-
We can download it for free from the following website: https://www.python.org/
data:image/s3,"s3://crabby-images/dfb5c/dfb5c590f0f015681ec661e9d8eb2089c9a7fe9f" alt=""
-
Open the .exe installer file.
-
Make sure you tick the "Add Python 3. to PATH" checkbox and click on "Install Now",
data:image/s3,"s3://crabby-images/498ce/498ce2bba2ce9a692ab536ccbcf39c75ca4518e0" alt=""
-
Verify the installation was successful by opening a command prompt and running the python command.
data:image/s3,"s3://crabby-images/2b3a0/2b3a081f4a5178f05ec36e5adc4e290c04b76c74" alt=""
Type python - -version
Python installed on the PC.
The Hello World
-
Python is an interpreted programming language.
-
We need to write Python (.py) files in a text editor and then put those files into the python interpreter to be executed.
-
Where HelloWorld.py is the name of your python file.
-
We wrote the one line program in a text editor.
data:image/s3,"s3://crabby-images/c8022/c8022a3957e3cb43469d0723fa4a5d42582381b4" alt=""
-
Save the python file, navigate the path on the command line.
-
To run the file, type python helloworld.py
-
The the print line shows here.
data:image/s3,"s3://crabby-images/2569d/2569d5eb8a795602d28629c5c6de63bd1067367e" alt=""
To run the python file
Here is the output.
Python Command Line
-
After running the Python command, the prompt changed to >>>
-
For a quick test, we can type commands (code) into the Python prompt results in answers in Python.
data:image/s3,"s3://crabby-images/a96f5/a96f5e78b05e00619994b5bbf26a5415cd3faa6c" alt=""
To pring the string
Operator
Operator & String
Python function
We got our first error
Python Command Line
Setting up Python with Sublime
-
To write the python program with Sublime Text 3 editor and make the editor compatible with python codes, here are some steps:
-
On Sublime Text, go to Tools > Command Pallets > type Install-Package Controller > click to install.
-
Type and install SublimeREPL or Python 3.
-
This plug-in lets the user to an interactive interpreter for several languages.
data:image/s3,"s3://crabby-images/e2f4e/e2f4e977cf3e667e690570a061e1bfda2cd33bed" alt=""
Install the Python 3 plug-in
-
For command line output in the editor, go to Tools > Built System > select Python.
data:image/s3,"s3://crabby-images/0c508/0c508a97b6d5a201596760cc0fde03bc2c59ce85" alt=""
-
Hit Ctrl + B or Tool menu > Build for command line output.
data:image/s3,"s3://crabby-images/9678b/9678bc12aef3139c8f075adb9c98edde06db3a11" alt=""
Coding window
Command line wondow
(output)
Python Syntax
Indentations in Python
-
Python uses indentation to indicate a block of codes.
-
It gives an error if no indent in a block.
data:image/s3,"s3://crabby-images/72fbe/72fbebf15c79e25c8689169315f3f0fdd29b3105" alt=""
Indentation
No-Indentation
Comments
data:image/s3,"s3://crabby-images/60074/600741012170df46bc76898850b977765831965f" alt=""
data:image/s3,"s3://crabby-images/f6aed/f6aed9d0999dec0e759a8e72ad44c012eddb6768" alt=""
Variable Declaration
-
Python has no command for declaring a variable.
-
The variable is being declared when we assign a value.
-
The right side of the = operator is being assigned to a variable.
-
The variable type keeps changing after re-assign.
-
Varible name should start with alphabet or underscore & can contain numbers, alphabets or underscore.
data:image/s3,"s3://crabby-images/f9a92/f9a92c1e5e558bf791163dc342a38c8175229ded" alt=""
Variable declaration
Datatypes
-
The data stored in memory can be any types.
-
To verify the type of an object in Python, use the type( ) function:
-
Here are some Python datatypes.
Datatypes
Number
stores number
String
"char"
List
['a','b','c']
Tuple
('a', 'b', 'c')
Dictionary
{'key' : 'value'}
value can't change
Integer
100
Float
100.12
Complex
5j, 3=4j
Number
-
Number objects are created when you assign a value.
String:
-
Stores number of character.
-
In Python, 'hello' is the same as "hello".
-
Subsets of strings can be taken using the slice operator ([ ] and [ : ] ) with index.
List [ ]
-
Lists are the most versatile of Python's compound data types. (multiple datatypes)
-
A list contains items separated by commas and enclosed within square brackets [ ].
Tuple ( )
-
Unlike List, the value in a tuple cannot be changed.
-
It is a read-only List.
-
It is enclosed within parentheses.
Dictionary { }
-
Dictionary is a kind of hash table type.
-
It is a collection which is unordered, changeable and indexed.
-
It is also possible to use the dict() constructor to make a dictionary.
data:image/s3,"s3://crabby-images/9a804/9a8045bf735f03dc8f57412252211422407d9ce2" alt=""
-
There is some function for accessing & manipulating the string, tuple, list, and dictionary.
data:image/s3,"s3://crabby-images/d6e38/d6e38763e514ddf168f8d03521a896d8a2bb36c5" alt=""
Type Casting
-
We can specify a type on to a declared variable.
-
Casting in python are done using some below functions:
Operator
-
Operators are used to perform some operation to a variable.
-
Similar to another program, Python has different types of operators as follows:
-
Arithmetic operators ( + - * / % ** // )
-
Assignment operator ( = += -= %= >>= |= ^= )
-
Comparison operator ( == != < > >= <= )
-
Logical operator ( and or not )
-
Identity operators ( is is not )
-
Membership operators ( in not in )
-
Bitwise operator ( & | ^ ~ << >> )
Conditional Statement
-
Python supports comparison operator to make a condition.
-
Thes conditions can be used in a loop and if condition.
-
On condition we need to use indentation for the code.
if statement
-
if the keyword is used to execute some code in a specific condition.
if elif statement
-
elif keyword is used in python, if the previous conditions were not true, then do this condition.
if else statement
-
If all the previous conditions were false, then perform else statement.
data:image/s3,"s3://crabby-images/806d3/806d3a098e026ab0e1156c2ac01e55e48867877c" alt=""
Loop control statement
-
For iteration, there are 2 loop in python:
-
For Loop: Iterates the statement for a limited time, when the condition is true.
-
While Loop: The statements are being executed unless the given condition is false.
data:image/s3,"s3://crabby-images/2e61d/2e61dbf98b4cb18e87b967f1f09c48c5cd74110c" alt=""
// For loop
-
In Python, else statement can be associated with while and for loop.
data:image/s3,"s3://crabby-images/c4e4c/c4e4c135552cd39b025fbe10cb8d883ed3a1eae9" alt=""
// While loop
// While - else
Loop control statement
-
Inside a loop, python has 3 statement to control the loop:
-
pass: When we have no statement to pass.
-
continue: To skip the rest of the body of the loop, and continue iterating.
-
break: Terminates the loop statement and transfers execution to the statement immediately.
data:image/s3,"s3://crabby-images/585fd/585fd93490809ad95d84ba044cf10085fa09072e" alt=""
// continue
// break
1st loop
2nd loop
Programing Concept
function
-
A Function is a block of code runs only when it is called.
-
We can pass parameter (value or reference).
-
The function block starts with def keyword followed by the function name and parentheses( ).
-
And the function block indented after column :
-
The function can return a value.
data:image/s3,"s3://crabby-images/94557/94557186119ebbba2a39c872f178fadd36918f54" alt=""
module
-
Like a library, a module is a file (.py) consisting of Python code; classes, functions & variable.
-
We can use that module in our application by import keyword followed by module name.
-
While python interpreter gets import statement it looks for the corresponding module file here:​
-
Current path
-
Shell variable path
-
Default path: C:\Users\SPS\AppData\Local\Programs\Python
Built-in Module
-
Python comes with some built-in modules. (eg. sys, io, platform)
-
For easy work, we can import those.
data:image/s3,"s3://crabby-images/0808c/0808cd9733f136c88cfa4017b7e467957ca0fe9b" alt=""
User-defined Module
-
A user can make a module by having the required variable, function and classes.
-
Save the file as .py extension, and keep in the current path.
-
And use those functions, value form that python file.
Python Package Manager
-
Python has a Package manager for downloading different the modules.
-
The later version of Python 3.4 has installed pip.
-
Here how to install a package:
data:image/s3,"s3://crabby-images/e4a75/e4a75b2c8d821352f21e3c5c9ce57359c85877dc" alt=""
To download & install camelcase module
-
Once the package is installed we can use that.
data:image/s3,"s3://crabby-images/56b8d/56b8df25e65d8ce2da14dd6217d71cf951740daf" alt=""
File I/O Handling
-
Python provides 2 functions to get the user input.​
-
raw_input ( )
-
input( )
-
We can create, read, update & delete the files using some functions.
-
The open( filename, mode ) function takes two parameters; filename, and mode.
-
r : Read
-
a : Append
-
w : Write
-
x : Create
-
For handing mode of file:
-
t: Text mode
-
b: Binary mode
Write File
-
Here is an example of writing a file.
data:image/s3,"s3://crabby-images/004ff/004ffe65d9f3771215ddb906d46e422a2537a90b" alt=""
-
The text file gets affected as below.
data:image/s3,"s3://crabby-images/d9c3d/d9c3dcbbd7ef2620872f052afdabedfb9a5183ff" alt=""
Read File
-
In python, open( ) function returns a file object, where it has a read( ) function is used to read the content.​
-
Here is the example for reading the text file data as string.
data:image/s3,"s3://crabby-images/f8660/f86609ab59490a423d94b6814b76b573952371d1" alt=""
Exersice: Read the 2nd and 4th line of the file.
data:image/s3,"s3://crabby-images/58ffb/58ffb9edb95d0f93d45824bffb0bca378ab51339" alt=""
OS Module
-
The is os module which allows us to remove the file and rename the file as well.
-
ps.remove("note.txt") : Remove a file in local directory.
-
os. rename("old.txt","new.txt") : Rename a file
-
os.mkdir("Folder1") : Make a new folder.
-
os.getchwd( ) : Get the current working directory.
-
os.chdir("/Folder/SPS/qPlus") : To chage the current working directory.
-
data:image/s3,"s3://crabby-images/f2835/f2835897b37b52c28d7aea52e821029740ee2dd2" alt=""
Python & MySQL
-
We can use Python in a database application.
-
Here we have MySQL database installed to work with.
-
We can choose any database for our application.
MySQL Driver
-
In order to work with a MySQL database in Python, we need to install a driver for respective database.
-
MySQL Connector is the driver we are going to intall on PIP.
-
We can download and install the driver from the internet.
-
Open the PIP path in CMD > type python -m pip install mysql -connector
data:image/s3,"s3://crabby-images/e1752/e1752c8f69e118727144a51ea364d4c66d4b83c2" alt=""
Download & Install the mysql connector on pip
Create Connection
-
After installing the driver, we can create a connection,
-
We need to import module, create a connection object with a database credential.
-
A short program for testing the connection between Python and MySQL.
data:image/s3,"s3://crabby-images/44340/443406bdd737c157b4d55d6bcc294f0875fb15f1" alt="Screenshot_3.jpg"
Connection established.
SELECT Table
-
To run any query on database, we need to create a cursor class object.
-
The cursor object allows us to run the query & handle the returned record.
-
In the MySQL database, we have the following data in a database.
data:image/s3,"s3://crabby-images/b65aa/b65aa235f189c64e7962c88509b7b8b54a246192" alt="Screenshot_1.jpg"
-
There are some functions to getting the record from the database on below.
-
cursor.fetchall ( ) - Returns all rows from executed records.
-
cursor.fetchone ( ) - Returns only one row.(first row)​​
-
-
Here is a program for SELECT query and getting the records.
data:image/s3,"s3://crabby-images/249c1/249c19fa446715d745c53d3faae7f5f0d79e133a" alt="Screenshot_2.jpg"
SELECT Table
INSERT Table
-
To insert the data from Python to MySQL can be done using by following steps.
-
First: Call the execute ( ) function with query & data as an argument.
-
Second: Call commit ( ) function for making changes on database.
-
For inserting to database functions are:
-
cursor.execute (sql query , data) - For inserting one-row
-
cursor.executemany (sql query, data_Tuple) - For inserting multiple rows.
-
dbConn.commit ( ) - For saving the chages.
-
data:image/s3,"s3://crabby-images/d53ef/d53efe75be52169996644ca66bcad445209c3103" alt="Screenshot_1.jpg"
INSERT Table
-
The GIF shows how it works after executing the above python program & checked on MySQL database.
data:image/s3,"s3://crabby-images/6e992/6e9928b1e5c5aa4ab83fb1360c73c46e8ebd8471" alt="insert Table Python.gif"
Excel To Database
-
Here we are going to import excel files in Python and write those spreadsheet data into databse.
-
There are several modules available for work with a spreadsheet.​
data:image/s3,"s3://crabby-images/a7f71/a7f715db0f5a5722264a708d31f9afb49ce47f69" alt="download.png"
Data
Excel
data:image/s3,"s3://crabby-images/c396c/c396c642f1e21c101a36d07f5ffc530790e5bb78" alt="images.jpg"
python
Data
data:image/s3,"s3://crabby-images/62388/623889d3f825c9b7698bade757f175faee16d1e5" alt="menggunakan-mysql-252x232.png"
mySQL Databse
-
In this case, we will download and install xlrd module.
-
To do so, open CMD > type and enter pip install xlrd
data:image/s3,"s3://crabby-images/f282a/f282a363de4374b1506f37a3e24eafa7de951d3f" alt="Screenshot_1.jpg"
-
The below program is for importing a excel file from the local directory.
-
And inserting to MySQL database.
data:image/s3,"s3://crabby-images/16189/1618981a9b6c7ea2a87e92a5ad69dde50e0f83c2" alt="Screenshot_1.jpg"
-
After running the python program, the 4 rows are been updated to database.
data:image/s3,"s3://crabby-images/c1c2b/c1c2b7401309fcc96684897890fc46ecfcff4322" alt="Screenshot_4.jpg"
Python Graphics
-
For graphic work, there are several modules we can put on to work in python.
Python Turtle
-
Turtle is a python module for drawing comes with python package.
-
All we need to import the module, make an instance, draw a shape, and put on the screen.
-
Here is the following steps on below.
data:image/s3,"s3://crabby-images/1ec86/1ec8623d239708a5ee6fe07e78304868d843514b" alt=""
Turtle Function
-
Here are some turtle functions of turtle module for drawing.
Exercise
-
Draw a circle, line, rectangle & star.
data:image/s3,"s3://crabby-images/bb3be/bb3be29d78453250cbdf84f80872d352eb5cd16d" alt="Screenshot_1.jpg"
-
Output:
data:image/s3,"s3://crabby-images/37092/3709224a2e8424a2d5a007799f32c4524c2ce740" alt="DrawingPython.gif"
Programs
Program 1
-
Finding the first non-repeated character in String.
-
Input: stonepfofits
-
Output: n
data:image/s3,"s3://crabby-images/5a955/5a955d16a659de58c11b3503a56f7b336e929a54" alt=""
Program 2
-
Find the Permutation of string.
-
Input: ab
-
Output: ab, ba
data:image/s3,"s3://crabby-images/d4362/d436257867ce67d04abcbe7a90f13264a1e512ca" alt=""
Program 3
-
Find Digit Identification if the string has any number.
-
Input: Stone123Profits
-
Output: True, if the string contains a number; False, if the string contains a number
data:image/s3,"s3://crabby-images/ce046/ce046096cb7fff526cda1100ab84374a0a463c7f" alt=""
Program 4
-
Find and Replace the 1st highest repeated character with user given character.
-
Input: abcabab
-
Output: pbcpbpb
data:image/s3,"s3://crabby-images/11313/113130fdb5a78680a8d726c2dd784fc077c46993" alt=""
Program 5
-
Write a program to print Diamond pattern.
-
Input: 5
-
Output: pattern
data:image/s3,"s3://crabby-images/116f5/116f5d28fd71b37e6ea31ca855e5c17a65c98473" alt=""
Program 6
-
Write a program to sum the numbers in a string.
-
Input: stone123profits7
-
Output: 130
data:image/s3,"s3://crabby-images/5b219/5b21995f9449c7d1ec190bdb11a9fdacbba4c026" alt=""