Python Ppt
Python Ppt
1
User Program
Filename, preferred extension is py
2
Feb 15, 2025 Programming
IN[1]: Python Shell Prompt
IN[2]:
User Commands
IN[3]: (Statements)
IN[4]: ( )
Outputs
4
Feb 15, 2025 Programming
input
• Take as argument a string to print as a prompt
• Returns the user typed value as a string
– details of how to process user string later
IN[1]:
IN[2]: ( )
IN[3]:
7
Feb 15, 2025 Programming
Types in Python
• Scalar
– Indivisible objects that do not have internal
structure
– int (signed integers), float (floating point), bool
(Boolean), NoneType
• NoneType is a special type with a single value
• The value is called None
• Non-Scalar
– Objects having internal structure
– str (strings)
8
Feb 15, 2025 Programming
Example of Types
9
Feb 15, 2025 Programming
Type Conversion (Type Cast)
10
Feb 15, 2025 Programming
Type Conversion Examples
Note that float to int conversion
is truncation, not rounding off
11
Feb 15, 2025 Programming
Type Conversion and Input
12
Feb 15, 2025 Programming
Operators
• Arithmetic + - * // / % **
13
Feb 15, 2025 Programming
Variables
• A name associated with an m
object 64
• Assignment used for binding Acads
m = 64; c
3.1416
c = ‘Acads’;
f = 3.1416; f
15
Feb 15, 2025 Programming
Multiple Assignments
• Python allows multiple assignments
x, y = 10, 20 Binds x to 10 and y to 20
17
02/15/2025 Programming
Binary Operations
Op Meaning Example Remarks
+ Addition 9+2 is 11
9.1+2.0 is 11.1
- Subtraction 9-2 is 7
9.1-2.0 is 7.1
* Multiplication 9*2 is 18
9.1*2.0 is 18.2
/ Division 9/2 is 4.25 In Python3
9.1/2.0 is 4.55 Real div.
// Integer Division 9//2 is 4
% Remainder 9%2 is 1
18
02/15/2025 Programming
The // operator
• Also referred to as “integer division”
• Result is a whole integer (floor of real
division)
– But the type need not be int
– the integral part of the real division
– rounded towards minus infinity
• Examples
9//4 is 2 (-1)//2 is -1 (-1)//(-2) is 0
1//2 is 0 1//(-2) is -1 9//4.5 is 2.0
19
02/15/2025 Programming
The % operator
• The remainder operator % returns the
remainder of the result of dividing its
first operand by its second.
9%4 is 1 (-1)%2 is 1 (-1)//(-2) is 0
9%4.5 is 0.0 1%(-2) is 1 1%0.6 is 0.4
Ideally: x == (x//y)*y + x %y
20
02/15/2025 Programming
Conditional Statements
• In daily routine
– If it is very hot, I will skip
exercise.
– If there is a quiz tomorrow, I will
first study and then sleep.
Otherwise I will sleep now.
– If I have to buy coffee, I will
go left. Else I will go
straight. 21
Feb 15, 2025 Programming
if-else statement
• Compare two integers and print the min.
22
Feb 15, 2025 Programming
Indentation
• Indentation is important in Python
– grouping of statement (block of statements)
– no explicit brackets, e.g. { }, to group statements
x,y = 6,10 Run
x the program
y
if x < y: 6 10
print (x)
else:
print (y) ed Output
i p p
sk the min’)
print (‘is 6 23
Feb 15, 2025 Programming
if statement (no else!)
• General form of the if statement
e
if boolean-expr : tru
fals
e
S1
S1
S2
• Execution of if statement S2
– First the expression is evaluated.
– If it evaluates to a true value, then S1 is
executed and then control moves to the S2.
– If expression evaluates to false, then control
moves to the S2 directly.
24
Feb 15, 2025 Programming
if-else statement
• General form of the if-else statement
if boolean-expr : rt u
e
fa
S1
ls
e
else: S1 S2
S2
S3 S3
• Execution of if-else statement
– First the expression is evaluated.
– If it evaluates to a true value, then S1 is executed and
then control moves to S3.
– If expression evaluates to false, then S2 is executed
and then control moves to S3.
– S1/S2 can be blocks of statements! 25
Feb 15, 2025 Programming
Nested if, if-else
if a <= b:
if a <= c:
…
else:
…
else:
if b <= c) :
…
else:
… 26
Feb 15, 2025 Programming
Elif
• A special kind of nesting is the chain of if-
else-if-else-… statements
• Can be written elegantly using if-elif-..-else
if cond1: if cond1:
s1 s1
else: elif cond2:
if cond2: s2
s2 elif cond3:
else: s3
if cond3: elif …
s3 else
else: last-block-of-stmt
…
27
Feb 15, 2025 Programming
Summary of if, if-else
• if-else, nested if's, elif.
• Multiple ways to solve a problem
–issues of readability,
maintainability
–and efficiency
28
Feb 15, 2025 Programming
Class Quiz
• What is the value of expression:
(5<2) and (3/0 > 1)
c) False
The correct answer is
False
d) True
29
Feb 15, 2025 Programming
Short-circuit Evaluation
• Do not evaluate the second operand of binary
short-circuit logical operator if the result can be
deduced from the first operand
– Also applies to nested logical operators
33
Feb 15, 2025 Programming
Caution about Using Floats
• The value stored internally for the decimal
number 0.1 is the binary fraction
0.00011001100110011001100110011001100110011001100110011010
35
Feb 15, 2025 Programming
Programming using Python
Loops
36
Feb 15, 2025 Python Programming
Printing Multiplication Table
5 X 1 = 5
5 X 2 = 10
5 X 3 = 15
5 X 4 = 20
5 X 5 = 25
5 X 6 = 30
5 X 7 = 35
5 X 8 = 40
5 X 9 = 45
5 X 10 = 50
37
Feb 15, 2025 Python Programming
Program…
n = int(input('Enter a number:
Too much'))
print (n, 'X', 1, '=', n*1)
repetition!
print (n, 'X', 2, '=', n*2)
Can I avoid
print (n, 'X', 3, '=', n*3) it?
print (n, 'X', 4, '=', n*4)
print (n, 'X', 5, '=', n*5)
print (n, 'X', 6, '=', n*6)
….
38
Feb 15, 2025 Python Programming
Printing Multiplication Table
Loop Exit
i <=10
TRUE FALSE
Loop 39
Feb 15, 2025 Python Programming
Printing Multiplication Table
Input n
i=1
TRUE
i <=10
FALSE n = int(input('n=? '))
i=1
Print n x i = ni Stop
i = i+1
40
Feb 15, 2025 Python Programming
While Statement
while (expression):
S1 expression
FALSE
S2
TRUE
S1 S2
1. Evaluate expression
2. If TRUE then
a) execute statement1
b) goto step 1.
3. If FALSE then execute statement2.
41
Feb 15, 2025 Python Programming
For Loop
• Print the sum of the reciprocals of the
first 100 natural numbers.
43
Feb 15, 2025 Python Programming
range
• range(s, e, d)
– generates the list:
[s, s+d, s+2*d, …, s+k*d]
where s+k*d < e <= s+(k+1)*d
• range(s, e) is equivalent to range(s, e, 1)
• range(e) is equivalent to range(0, e)
Exercise: What if d is negative? Use python
interpreter to find out. 44
Feb 15, 2025 Python Programming
Quiz
• What will be the output of the following
program
f(unctions)
47
Feb 15, 2025 Programming, Functions
Parts of a function
Input
48
Feb 15, 2025 Output
Programming, Functions
def max (a, b):
‘’’return maximum among a and b’’’
keyword if (a > b):
return a 2 arguments
else: a and b
Function Name return b (formal args)
In[3] : help(max)
Help on function max in module __main__:
max(a, b)
return maximum among a and b
50
Feb 15, 2025 Programming, Functions
Keyword Arguments
Note use of [0]
def printName(first, last, initials) : to get the first
if initials: character of a
string. More on
print (first[0] + '. ' + last[0] + '.') this later.
else:
print (first, last)
Call Output
printName('Acads', 'Institute', False) Acads Institute
printName('Acads', 'Institute', True) A. I.
printName(last='Institute', initials=False, first='Acads') Acads Institute
printName('Acads', initials=True, last='Institute') A. I.
51
Feb 15, 2025 Programming, Functions
Keyword Arguments
• Parameter passing where formal is bound to
actual using formal's name
• Can mix keyword and non-keyword arguments
– All non-keyword arguments precede keyword
arguments in the call
– Non-keyword arguments are matched by position
(order is important)
– Order of keyword arguments is not important
52
Feb 15, 2025 Programming, Functions
Default Values
def printName(first, last, initials=False) :
if initials:
print (first[0] + '. ' + last[0] + '.')
Note the use
else: of “default”
value
print (first, last)
Call Output
printName('Acads', 'Institute') Acads Institute
printName(first='Acads', last='Institute', initials=True) A. I.
printName(last='Institute', first='Acads') Acads Institute
printName('Acads', last='Institute') Acads Institute
53
Feb 15, 2025 Programming, Functions
Default Values
• Allows user to call a function with fewer
arguments
• Useful when some argument has a fixed value
for most of the calls
• All arguments with default values must be at
the end of argument list
– non-default argument can not follow default
argument
54
Feb 15, 2025 Programming, Functions
Globals
• Globals allow functions to communicate with
each other indirectly
– Without parameter passing/return value
• Convenient when two seemingly “far-apart”
functions want to share data
– No direct caller/callee relation
• If a function has to update a global, it must re-
declare the global variable with global
keyword.
55
Feb 15, 2025 Programming, Functions
Globals
PI = 3.14 >>> print(area (100))
def perimeter(r): 31400.0
return 2 * PI * r >>> print(perimeter(10))
def area(r): 62.800000000000004
return PI * r * r >>> update_pi()
def update_pi(): >>> print(area(100))
global PI 31415.999999999996
PI = 3.14159 >>> print(perimeter(10))
62.832
defines PI to be of float type with value
3.14. PI can be used across functions. Any
change to PI in update_pi will be visible to 56
all due to the use of global.
Feb 15, 2025 Programming, Functions
Programming with Python
S T R I NGS
T UP L E S
L I S T S
57
Feb 15, 2025 Programming
Strings
• Strings in Python have type str
• They represent sequence of characters
– Python does not have a type corresponding to
character.
• Strings are enclosed in single quotes(') or
double quotes(“)
– Both are equivalent
• Backslash (\) is used to escape quotes and
special characters
58
Feb 15, 2025 Programming
Strings
59
Feb 15, 2025 Programming
Length of a String
• len function gives the length of a string
\n is a single character:
the special character
representing newline 60
Feb 15, 2025 Programming
Concatenate and Repeat
• In Python, + and * operations have special
meaning when operating on strings
• + is used for concatenation of (two) strings
• * is used to repeat a string, an int number of
time
• Function/Operator Overloading
61
Feb 15, 2025 Programming
Concatenate and Repeat
62
Feb 15, 2025 Programming
Indexing
• Strings can be indexed
• First character has index 0
63
Feb 15, 2025 Programming
Indexing
• Negative indices start counting from the right
• Negatives indices start from -1
• -1 means last, -2 second last, ...
64
Feb 15, 2025 Programming
Indexing
• Using an index that is too large or too small
results in “index out of range” error
65
Feb 15, 2025 Programming
Slicing
• To obtain a substring
• s[start:end] means substring of s starting at
index start and ending at index end-1
• s[0:len(s)] is same as s
• Both start and end are optional
– If start is omitted, it defaults to 0
– If end is omitted, it defaults to the length of string
• s[:] is same as s[0:len(s)], that is same as s
66
Feb 15, 2025 Programming
Slicing
67
Feb 15, 2025 Programming
More Slicing
69
Feb 15, 2025 Programming
Tuples
• A tuple consists of a number of values
separated by commas
70
Feb 15, 2025 Programming
Nested Tuples
• Tuples can be nested
71
Feb 15, 2025 Programming
Length of a Tuple
• len function gives the length of a tuple
72
Feb 15, 2025 Programming
More Operations on Tuples
• Tuples can be concatenated, repeated,
indexed and sliced
73
Feb 15, 2025 Programming
Unpacking Sequences
• Strings and Tuples are examples of sequences
– Indexing, slicing, concatenation, repetition
operations applicable on sequences
• Sequence Unpacking operation can be applied
to sequences to get the components
– Multiple assignment statement
– LHS and RHS must have equal length
74
Feb 15, 2025 Programming
Unpacking Sequences
( )
75
Feb 15, 2025 Programming
Lists
• Ordered sequence of values
• Written as a sequence of comma-separated
values between square brackets
• Values can be of different types
– usually the items all have the same type
76
Feb 15, 2025 Programming
Lists
• List is also a sequence type
– Sequence operations are applicable
77
Feb 15, 2025 Programming
Lists
• List is also a sequence type
– Sequence operations are applicable
Repetition
( )
78
Feb 15, 2025 Programming
More Operations on Lists
• L.append(x) • L.pop()
• L.extend(seq) • L.index(x)
• L.insert(i, x) • L.count(x)
• L.remove(x) • L.sort()
• L.pop(i) • L.reverse()
x is any value, seq is a sequence value (list, string, tuple, …),
i is an integer value
79
Feb 15, 2025 Programming
Mutable and Immutable Types
• Tuples and List types look very similar
• However, there is one major difference: Lists
are mutable
– Contents of a list can be modified
• Tuples and Strings are immutable
– Contents can not be modified
80
Feb 15, 2025 Programming
Summary of Sequences
Operation Meaning
seq[i] i-th element of the sequence
len(seq) Length of the sequence
seq1 + seq2 Concatenate the two sequences
num*seq
seq*num Repeat seq num times
82
Feb 15, 2025 Programming
Programming with Python
83
Feb 15, 2025 Esc101, Strings
Sets
• An unordered collection with no duplicate
elements
• Supports
– membership testing
– eliminating duplicate entries
– Set operations: union, intersection, difference, and
symmetric difference.
84
Feb 15, 2025 Programming
Sets
{ }
85
Feb 15, 2025 Programming
Set Operations
{ }
{ }
{ }
MyList=[2,4,6,8,10]
MySet=set(MyList)
{ }
Print(MySet)
{ }
Output: ?
86
Feb 15, 2025 Programming
Dictionaries
• Unordered set of key:value pairs,
• Keys have to be unique and immutable
• Key:value pairs enclosed inside curly braces
{...}
• Empty dictionary is created by writing {}
• Dictionaries are mutable
– add new key:value pairs,
– change the pairing
– delete a key (and associated value) 87
Feb 15, 2025 Programming
Operations on Dictionaries
Operation Meaning
len(d) Number of key:value pairs in d
d.keys() List containing the keys in d
d.values() List containing the values in d
k in d True if key k is in d
d[k] Value associated with key k in d
d.get(k, v) If k is present in d, then d[k] else v
d[k] = v Map the value v to key k in d
(replace d[k] if present)
del d[k] Remove key k (and associated value) from d
for k in d Iterate over the keys in d
88
Feb 15, 2025 Programming
Operations on Dictionaries
89
Feb 15, 2025 Programming
Operations on Dictionaries
90
Feb 15, 2025 Programming
Operations on Dictionaries
91
Feb 15, 2025 Programming
Dictionary Construction
• The dict constructor: builds dictionaries
directly from sequences of key-value pairs
92
Feb 15, 2025 Esc101, Strings
Programming with Python
File I/O
93
Feb 15, 2025 Programming
File I/O
• Files are persistent storage
• Allow data to be stored beyond program
lifetime
• The basic operations on files are
– open, close, read, write
• Python treat files as sequence of lines
– sequence operations work for the data read from
files
94
Feb 15, 2025 Programming
File I/O: open and close
open(filename, mode)
• While opening a file, you need to supply
– The name of the file, including the path
– The mode in which you want to open a file
– Common modes are r (read), w (write), a (append)
• Mode is optional, defaults to r
• open(..) returns a file object
• close() on the file object closes the file
– finishes any buffered operations
95
Feb 15, 2025 Programming
File I/O: Example
• Do some writing
• How to do it?
• see the next few slides
96
Feb 15, 2025 Programming
File I/O: read, write and append
• Reading from an open file returns the
contents of the file
– as sequence of lines in the program
• Writing to a file
– IMPORTANT: If opened with mode 'w', clears the
existing contents of the file
– Use append mode ('a') to preserve the contents
– Writing happens at the end
97
Feb 15, 2025 Programming
File I/O: Examples
98
Feb 15, 2025 Programming
File I/O: Examples
( )
( )
99
Feb 15, 2025 Programming
File I/O: Examples
( )
100
Feb 15, 2025 Programming
File I/O: Examples
Note the use of for ... in
for sequence
( )
]
101
Feb 15, 2025 Programming
File I/O: Examples
( )
( )
( )
102
Feb 15, 2025 Programming
Programming using Python
103
Welcome Python Programming
Modules
• As program gets longer, need to organize them for
easier access and easier maintenance.
• Reuse same functions across programs without
copying its definition into each program.
• Python allows putting definitions in a file
– use them in a script or in an interactive instance of the
interpreter
• Such a file is called a module
– definitions from a module can be imported into other
modules or into the main module
104
Feb 15, 2025 Programming
Modules
• A module is a file containing Python
definitions and statements.
• The file name is the module name with the
suffix .py appended.
• Within a module, the module’s name is
available in the global variable __name__.
105
Feb 15, 2025 Programming
Modules Example
fib.py - C:\
106
Feb 15, 2025 Programming
Modules Example
108
Feb 15, 2025 Programming
Importing ALL Functions
• To import all functions from a module, in the current
symbol table
112
Feb 15, 2025 Programming
A sound Package
https://docs.python.org/3/tutorial/modules.html
113
Feb 15, 2025 Programming
A sound Package
https://docs.python.org/3/tutorial/modules.html
114
Feb 15, 2025xs Programming
__init.py__
• The __init__.py files are required to make
Python treat directories containing the file as
packages.
• This prevents directories with a common name,
such as string, unintentionally hiding valid
modules that occur later on the module search
path.
• __init__.py can just be an empty file
• It can also execute initialization code for the
package
115
Feb 15, 2025 Programming
Importing Modules from Packages
https://docs.python.org/3/tutorial/
modules.html 116
Feb 15, 2025 Programming
Importing Modules from Packages
import sound.effects.echo
sound.effects.echo.echofilter(
input, output,
delay=0.7, atten=4
)
117
Feb 15, 2025 Programming
Importing Modules from Packages
from sound.effects import echo
• This also loads the submodule echo
• Makes it available without package prefix
• It can be used as:
echo.echofilter(
input, output,
delay=0.7, atten=4
)
118
Feb 15, 2025 Programming
Importing Modules from Packages
from sound.effects.echo import echofilter
echofilter(input, output,
delay=0.7, atten=4)
119