SlideShare a Scribd company logo
UNIT-II
IoT Systems –
Logical Design using Python
Outline
• Introduction to Python
• Installing Python
• Python Data Types & Data Structures
• Control Flow
• Functions
• Modules
• Packages
• File Input/Output
• Date/Time Operations
• Classes
Python
• Python is a general-purpose high level programming language and suitable for providing a solid
foundation to the reader in the area of cloud computing.
• The main characteristics of Python are:
• Multi-paradigm programming language
• Python supports more than one programming paradigms including object-oriented programming and structured
programming
• Interpreted Language
• Python is an interpreted language and does not require an explicit compilation step. The Python interpreter
executes the program source code directly, statement by statement, as a processor or scripting engine does.
• Interactive Language
• Python provides an interactive mode in which the user can submit commands at the Python prompt and interact
with the interpreter directly.
Python - Benefits
• Easy-to-learn, read and maintain
• Python is a minimalistic language with relatively few keywords, uses English keywords and has fewer syntactical constructions
as compared to other languages. Reading Python programs feels like English with pseudo-code like constructs. Python is easy
to learn yet an extremely powerful language for a wide range of applications.
• Object and Procedure Oriented
• Python supports both procedure-oriented programming and object-oriented programming. Procedure oriented paradigm allows
programs to be written around procedures or functions that allow reuse of code. Procedure oriented paradigm allows programs
to be written around objects that include both data and functionality.
• Extendable
• Python is an extendable language and allows integration of low-level modules written in languages such as C/C++. This is
useful when you want to speed up a critical portion of a program.
• Scalable
• Due to the minimalistic nature of Python, it provides a manageable structure for large programs.
• Portable
• Since Python is an interpreted language, programmers do not have to worry about compilation, linking and loading of
programs. Python programs can be directly executed from source
• Broad Library Support
• Python has a broad library support and works on various platforms such as Windows, Linux, Mac, etc.
Python - Setup
• Windows
• Python binaries for Windows can be downloaded from http://www.python.org/getit .
• For the examples and exercise in this book, you would require Python 2.7 which can be directly downloaded from:
http://www.python.org/ftp/python/2.7.5/python-2.7.5.msi
• Once the python binary is installed you can run the python shell at the command prompt using
> python
• Linux
#Install Dependencies
sudo apt-get install build-essential
sudo apt-get install libreadline-gplv2-dev libncursesw5-dev libssl-dev libsqlite3-dev tk-dev libgdbm-dev libc6-dev libbz2-dev
#Download Python
wget http://python.org/ftp/python/2.7.5/Python-2.7.5.tgz
tar -xvf Python-2.7.5.tgz
cd Python-2.7.5
#Install Python
./configure
make
sudo make install
Numbers
• Numbers
• Number data type is used to store numeric values. Numbers are immutable data types, therefore changing the value of a number data
type results in a newly allocated object.
#Integer
>>>a=5
>>>type(a)
<type ’int’>
#Floating
Point
>>>b=2.5
>>>type(b)
<type ’float’>
#Long
>>>x=9898878787676
L
>>>type(x)
<type ’long’>
#Complex
>>>y=2+5j
>>>y
(2+5j
)
>>>type(y)
<type
’complex’>
>>>y.rea
l 2
>>>y.ima
g 5
#Addition
>>>c=a+b
>>>
c
7.5
>>>type(c)
<type ’float’>
#Subtraction
>>>d=a-b
>>>
d
2.5
>>>type(d)
<type ’float’>
#Multiplicatio
n
>>>e=a*b
>>>
e
12.5
>>>type(e)
<type ’float’>
#Division
>>>f=b/a
>>>
f
0.5
>>>type(f)
<type float’>
#Power
>>>g=a**
2
>>>
g 25
Strings
• Strings
• A string is simply a list of characters in order. There are no limits to the number of characters you can have in a string.
#Create string
>>>s="Hello World!"
>>>type(s)
<type ’str’>
#String concatenation
>>>t="This is sample program."
>>>r = s+t
>>>r
’Hello World!This is sample program.’
#Get length of string
>>>len(s
) 12
#Convert string to integer
>>>x="100"
>>>type(s)
<type ’str’>
>>>y=int(x)
>>>
y
100
#Print string
>>>print s
Hello
World!
#Formatting output
>>>print "The string (The string (Hello
World!) has 12 characters
#Convert to upper/lower case
>>>s.upper()
’HELLO
WORLD!’
>>>s.lower()
’hello
world!’
#Accessing sub-strings
>>>s[0
] ’H’
>>>s[6:]
’World!’
>>>s[6:-1]
’World’
#strip: Returns a copy of the string with
the #leading and trailing characters
removed.
>>>s.strip("!"
) ’Hello
World’
Lists
• Lists
• List a compound data type used to group together other values. List items need not all have the same type. A list contains items
separated by commas and enclosed within square brackets.
#Create List
>>>fruits=[’apple’,’orange’,’banana’,’mango’]
>>>type(fruits)
<type ’list’>
#Get Length of List
>>>len(fruits
) 4
#Access List Elements
>>>fruits[1
] ’orange’
>>>fruits[1:3]
[’orange’, ’banana’]
>>>fruits[1:]
[’orange’, ’banana’, ’mango’]
#Appending an item to a list
>>>fruits.append(’pear’)
>>>fruits
[’apple’, ’orange’, ’banana’, ’mango’, ’pear’]
#Removing an item from a list
>>>fruits.remove(’mango’)
>>>fruits
[’apple’, ’orange’, ’banana’, ’pear’]
#Inserting an item to a list
>>>fruits.insert(1,’mango’)
>>>fruits
[’apple’, ’mango’, ’orange’, ’banana’, ’pear’]
#Combining lists
>>>vegetables=[’potato’,’carrot’,’onion’,’beans’,’
r adish’]
>>>vegetables
[’potato’, ’carrot’, ’onion’, ’beans’, ’radish’]
>>>eatables=fruits+vegetables
>>>eatables
[’appl
e’,
’mang
o’,
’orang
e’,
’banan
a’,
’pear’, ’potato’, ’carrot’, ’onion’, ’beans’,
’radish’]
#Mixed data types in a list
>>>mixed=[’data’,5,100.1,8287398L]
>>>type(mixed)
<type ’list’>
>>>type(mixed[0])
<type ’str’>
>>>type(mixed[1])
<type ’int’>
>>>type(mixed[2])
<type ’float’>
>>>type(mixed[3])
<type ’long’>
#Change individual elements of a list
>>>mixed[0]=mixed[0]+" items"
>>>mixed[1]=mixed[1]+1
>>>mixed[2]=mixed[2]+0.05
>>>mixed
[’data items’, 6, 100.14999999999999, 8287398L]
#Lists can be nested
>>>nested=[fruits,vegetables]
>>>nested
[[’apple’, ’mango’, ’orange’, ’banana’, ’pear’],
[’potato’, ’carrot’, ’onion’, ’beans’, ’radish’]]
Tuples
• Tuples
• A tuple is a sequence data type that is similar to the list. A tuple consists of a number of values separated by commas and enclosed
within parentheses. Unlike lists, the elements of tuples cannot be changed, so tuples can be thought of as read-only lists.
#Create a Tuple
>>>fruits=("apple","mango","banana","pineapple")
>>>fruits
(’apple’, ’mango’, ’banana’, ’pineapple’)
>>>type(fruits)
<type ’tuple’>
#Get length of tuple
>>>len(fruits
) 4
#Get an element from a tuple
>>>fruits[0
] ’apple’
>>>fruits[:2]
(’apple’,
’mango’)
#Combining tuples
>>>vegetables=(’potato’,’carrot’,’onion’,’radish’)
>>>eatables=fruits+vegetables
>>>eatables
(’apple’, ’mango’, ’banana’, ’pineapple’, ’potato’, ’carrot’, ’onion’, ’radish’)
Dictionaries
• Dictionaries
• Dictionary is a mapping data type or a kind of hash table that maps keys to values. Keys in a dictionary can be of any data type, though
numbers and strings are commonly used for keys. Values in a dictionary can be any data type or object.
#Create a dictionary
>>>student={’name’:’Mary’,’id’:’8776’,’major’:’CS’}
>>>student
{’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’}
>>>type(student)
<type ’dict’>
#Get length of a dictionary
>>>len(student)
3
#Get the value of a key in dictionary
>>>student[’name’]
’Mary’
#Get all items in a dictionary
>>>student.items()
[(’gender’, ’female’), (’major’, ’CS’), (’name’,
’Mary’), (’id’, ’8776’)]
#Get all keys in a dictionary
>>>student.keys()
[’gender’, ’major’, ’name’, ’id’]
#Get all values in a dictionary
>>>student.values()
[’female’, ’CS’, ’Mary’,
’8776’]
#Add new key-value pair
>>>student[’gender’]=’female’
>>>student
{’gende
r’: ’female’, ’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’}
#A value in a dictionary can be another dictionary
>>>student1={’name’:’David’,’id’:’9876’,’major’:’ECE’}
>>>students={’1’: student,’2’:student1}
>>>students
{’1’:
{’gende
r’: ’female’, ’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’},
’2’:
{
’
major’: ’ECE’, ’name’: ’David’, ’id’:
’9876’}}
#Check if dictionary has a key
>>>student.has_key(’name’)
True
>>>student.has_key(’grade’)
False
Type Conversions
#Convert to string
>>>a=10000
>>>str(a
)
’10000’
#Convert to int
>>>b="2013"
>>>int(b
) 2013
#Convert to float
>>>float(b
) 2013.0
#Convert to long
>>>long(b
) 2013L
#Convert to list
>>>s="aeiou"
>>>list(s)
[’a’, ’e’, ’i’, ’o’, ’u’]
#Convert to set
>>>x=[’mango’,’apple’,’banana’,’mango’,’banana’]
>>>set(x)
set([’mango’, ’apple’, ’banana’])
• Type conversion examples
Control Flow – if statement
• The if statement in Python is similar to the if statement in other languages.
>>>a = 25**5
>>>if a>10000:
print "More"
else:
print "Less"
More
>>>s="Hello World"
>>>if "World" in s:
s=s+"!"
print s
Hello World!
>>>if a>10000:
if a<1000000:
print "Between 10k and 100k"
else:
print "More than 100k"
elif a==10000:
print "Equal to 10k"
else:
print "Less than 10k"
More than 100k
>>>student={’name’:’Mary’,’id’:’8776’}
>>>if not student.has_key(’major’):
student[’major’]=’CS’
>>>student
{’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’}
Control Flow – for statement
• The for statement in Python iterates over items of any sequence (list, string, etc.) in the order in which they
appear in the sequence.
• This behavior is different from the for statement in other languages such as C in which an initialization,
incrementing and stopping criteria are provided.
for
Syntax: For iterating_var in sequence:
Execute Statements
Control Flow – while statement
• The while statement in Python executes the statements within the while loop as long as the while condition is
true.
#Prints even numbers upto 100
>>> i = 0
>>> while
i<=100: if i%2
== 0:
printi
i = i+1
Control Flow – range statement
• The range statement in Python generates a list of numbers in arithmetic progression.
#Generate a list of numbers from 10 - 100 with
increments of 10
>>>range(10,110,10)
[10, 20, 30, 40, 50, 60, 70, 80, 90,100]
#Generate a list of numbers from 0 – 9
>>>range (10)
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
Control Flow – break/continue statements
• The break and continue statements in Python are similar to the statements in C.
• Break
• Break statement breaks out of the for/while loop
• Continue
• Continue statement continues with the next iteration.
#Continue statement example
>>>fruits=[’apple’,’orange’,’banana’,’mango’]
>>>for item in fruits:
if item == "banana":
continue
else:
print item
apple
orange
mango
#Break statement example
>>>y=1
>>>for x in range(4,256,4):
y = y * x
if y >
512:
break
print y
4
32
384
Control Flow – pass statement
• The pass statement in Python is a null operation.
• The pass statement is used when a statement is required syntactically but you do not want any command or
code to execute.
>fruits=[’apple’,’orange’,’banana’,’mango’]
>for item in fruits:
if item == "banana":
pass
else:
print item
apple
orange
mango
Functions
• A function is a block of code that takes information in (in the form of
parameters), does some computation, and returns a new piece of
information based on the parameter information.
• A function in Python is a block of code that begins with the keyword
def followed by the function name and parentheses. The function
parameters are enclosed within the parenthesis.
• The code block within a function begins after a colon that comes after
the parenthesis enclosing the parameters.
• The first statement of the function body can optionally be a
documentation string or docstring.
students = { '1': {'name': 'Bob', 'grade': 2.5},
'2': {'name': 'Mary', 'grade': 3.5},
'3': {'name': 'David', 'grade': 4.2},
'4': {'name': 'John', 'grade': 4.1},
'5': {'name': 'Alex', 'grade': 3.8}}
def averageGrade(students):
“This function computes the average grade”
sum = 0.0
for key in students:
sum = sum + students[key]['grade']
average = sum/len(students)
return average
avg = averageGrade(students)
print (The average garde is: %0.2f" % (avg)))
Functions-Default Arguments
• Functions can have default values of the parameters.
• If a function with default values is called with fewer parameters or without any parameter, the default values of the
parameters are used
>>>def displayFruits(fruits=[’apple’,’orange’]):
print "There are %d fruits in the list" %
(len(fruits)) for item in fruits:
print item
#Using default arguments
>>>displayFruits(
) apple
orange
>>>fruits = [’banana’, ’pear’, ’mango’]
>>>displayFruits(fruits
) banana
pear
mango
Functions-Passing by Reference
• All parameters in the Python functions are passed by reference.
• If a parameter is changed within a function the change also reflected back in the calling function.
>>>def displayFruits(fruits):
print "There are %d fruits in the list" %
(len(fruits)) for item in fruits:
print item
print "Adding one more fruit"
fruits.append('mango')
>>>fruits = ['banana', 'pear', 'apple']
>>>displayFruits(fruits)
There are 3 fruits in the list
banana
pear
apple
#Adding one more fruit
>>>print "There are %d fruits in the list" %
(len(fruits)) There are 4 fruits in the list
Functions - Keyword Arguments
• Functions can also be called using keyword arguments that identifies the arguments by the parameter name when the
function is called.
>>>def
printStudentRecords(name,age=20,major=’CS’):
print "Name: " + name
print "Age: " + str(age)
print "Major: " + major
#This will give error as name is required argument
>>>printStudentRecords()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: printStudentRecords() takes at least 1
argument (0 given)
#name is a formal argument.
#**kwargs is a keyword argument that receives
all arguments except the formal argument as a
dictionary.
>>>def student(name, **kwargs):
print "Student Name: " + name
for key in kwargs:
print key + ’: ’ + kwargs[key]
>>>student(name=’Bob’, age=’20’, major = ’CS’)
Student Name: Bob
age: 20
major: CS
#Correct use
>>>printStudentRecords(name=’Alex’
) Name: Alex
Age: 20
Major:
CS
>>>printStudentRecords(name=’Bob’,age=22,major=’E
C E’)
Name: Bob
Age: 22
Major:
ECE
>>>printStudentRecords(name=’Alan’,major=’ECE’)
Name: Alan
Age: 20
Major:
ECE
Functions - Variable Length Arguments
• Python functions can have variable length arguments. The variable length arguments are passed to as a tuple to the
function with an argument prefixed with asterix (*)
>>>def student(name, *varargs):
print "Student Name: " + name
for item in varargs:
print item
>>>student(’Nav’)
Student Name: Nav
>>>student(’Amy’, ’Age:
24’) Student Name: Amy
Age: 24
>>>student(’Bob’, ’Age: 20’, ’Major:
CS’) Student Name: Bob
Age: 20
Major:
CS
Modules
• Python allows organizing the program
code into different modules which
improves the code readability and
management.
• A module is a Python file that defines
some functionality in the form of functions
or classes.
• Modules can be imported using the import
keyword.
• Modules to be imported must be present
in the search path.
#student module - saved as student.py
def averageGrade(students):
sum = 0.0
for key in students:
sum = sum + students[key]['grade']
average = sum/len(students)
return average
def printRecords(students):
print "There are %d students" %(len(students))
i=1
for key in students:
print "Student-%d: " % (i)
print "Name: " + students[key]['name']
print "Grade: " + str(students[key]['grade'])
i = i+1
#Using student module
>>>import student
>>>students = '1': 'name': 'Bob', 'grade': 2.5,
'2': 'name': 'Mary', 'grade': 3.5,
'3': 'name': 'David', 'grade': 4.2,
'4': 'name': 'John', 'grade': 4.1,
'5': 'name': 'Alex', 'grade': 3.8
>>>student.printRecords(students) There
are 5 students
Student-1:
Name: Bob Grade:
2.5 Student-2:
Name: David
Grade: 4.2 Student-
3:
Name: Mary Grade:
3.5 Student-4:
Name: Alex
Grade: 3.8
Student-5:
Name: John Grade:
4.1
>>>avg = student. averageGrade(students)
>>>print "The average garde is: %0.2f" % (avg)
3.62
# Importing a specific function from a module
>>>from student import averageGrade
# Listing all names defines in a module
>>>dir(student)
Packages
• Python package is hierarchical file structure that consists of
modules and subpackages.
• Packages allow better organization of modules related to a single
application environment.
# skimage package
listing
skimage/
init .py
Top level package
Treat directory as a
package
color/ color color
subpackage
init .py
colorconv.py
colorlabel.py
rgb_colors.py
draw/ draw draw subpackage
init .py
draw.py
setup.py
exposure/ exposure subpackage
init .py
_adapthist.py
exposure.py
feature/ feature subpackage
init .py
_brief.py
_daisy.py
...
File Handling
• Python allows reading and writing to files using the file
object.
• The open(filename, mode) function is used to get a file
object.
• The mode can be read (r), write (w), append (a), read and
write (r+ or w+), read-binary (rb), write-binary (wb), etc.
• After the file contents have been read the close function is
called which closes the file object.
# Example of reading line by line
>>>fp = open('file1.txt','r')
>>>print "Line-1: " + fp.readline()
Line-1: Python supports more than one programming paradigms.
>>>print "Line-2: " + fp.readline()
Line-2: Python is an interpreted language.
>>>fp.close()
# Example of reading an entire file
>>>fp = open('file.txt','r')
>>>content = fp.read()
>>>print content
This is a test file.
>>>fp.close()
# Example of reading lines in a loop
>>>fp = open(’file1.txt’,’r’)
>>>lines = fp.readlines()
>>>for line in lines:
print line
Python supports more than one programming paradigms.
Python is an interpreted language.
File Handling
# Example of seeking to a certain position
>>>fp = open('file.txt','r')
>>>fp.seek(10,0)
>>>content = fp.read(10)
>>>print content
ports more
>>>fp.close()
# Example of reading a certain number of bytes
>>>fp = open('file.txt','r')
>>>fp.read(10
) 'Python sup'
>>>fp.close()
# Example of getting the current position of read
>>>fp = open('file.txt','r')
>>>fp.read(10
) 'Python sup'
>>>currentpos = fp.tell
>>>print currentpos
<built-in method tell of file object at 0x0000000002391390>
>>>fp.close()
# Example of writing to a file
>>>fo = open('file1.txt','w')
>>>content='This is an example of writing to a file
in Python.'
>>>fo.write(content)
>>>fo.close()
Date/Time Operations
• Python provides several functions for date and time access and conversions.
• The datetime module allows manipulating date and time in several ways.
• The time module in Python provides various time-related functions.
# Examples of manipulating with date
>>>from datetime import date
>>>now = date.today()
>>>print "Date: " + now.strftime("%m-%d-
%y") Date: 07-24-13
>>>print "Day of Week: " +
now.strftime("%A") Day of Week: Wednesday
>>>print "Month: " +
now.strftime("%B") Month: July
>>>then = date(2013, 6, 7)
>>>timediff = now - then
>>>timediff.day
s 47
# Examples of manipulating with time
>>>import time
>>>nowtime = time.time()
>>>time.localtime(nowtime)
time.struct_time(tm_year=2013, tm_mon=7, tm_mday=24, tm_ec=51, tm_wday=2, tm_yday=205,
tm_isdst=0)
>>>time.asctime(time.localtime(nowtime))
'Wed Jul 24 16:14:51 2013'
>>>time.strftime("The date is %d-%m-%y. Today is a %A. It is %H hours, %M minutes and %S seconds
now.") 'The date is 24-07-13. Today is a Wednesday. It is 16 hours, 15 minutes and 14 seconds now.'
Classes
• Python is an Object-Oriented Programming (OOP) language. Python provides all the standard features of Object
Oriented Programming such as classes, class variables, class methods, inheritance, function overloading, and
operator overloading.
• Class
• A class is simply a representation of a type of object and user-defined prototype for an object that is composed of three things: a name,
attributes, and operations/methods.
• Instance/Object
• Object is an instance of the data structure defined by a class.
• Inheritance
• Inheritance is the process of forming a new class from an existing class or base class.
• Function overloading
• Function overloading is a form of polymorphism that allows a function to have different meanings, depending on its context.
• Operator overloading
• Operator overloading is a form of polymorphism that allows assignment of more than one function to a particular operator.
• Function overriding
• Function overriding allows a child class to provide a specific implementation of a function that is already provided by the base class. Child class
implementation of the overridden function has the same name, parameters and return type as the function in the base class.
Class Example
• The variable studentCount is a
class variable that is shared by
all instances of the class
Student and is accessed by
Student.studentCount.
• The variables name, id and
grades are instance variables
which are specific to each
instance of the class.
• There is a special method by
the name init () which is the
class constructor.
• The class constructor
initializes a new instance
when it is created. The
function del () is the class
destructor
# Examples of a class
class Student:
studentCount = 0
def init (self, name, id):
print "Constructor called"
self.name = name
self.id = id
Student.studentCount = Student.studentCount + 1
self.grades={}
def del (self):
print "Destructor called"
def getStudentCount(self):
return Student.studentCount
def addGrade(self,key,value):
self.grades[key]=value
def getGrade(self,key):
return self.grades[key]
def printGrades(self):
for key in self.grades:
print key + ": " + self.grades[key]
>>>s =
Student(’Steve’,’98928’)
Constructor called
>>>s.addGrade(’Math’,’90’)
>>>s.addGrade(’Physics’,’85’)
>>>s.printGrades()
Physics: 85
Math: 90
>>>mathgrade = s.getGrade(’Math’)
>>>print mathgrade
90
>>>count = s.getStudentCount()
>>>print count
1
>>>del s
Destructor called
Class Inheritance
• In this example Shape is the base class and Circle is the derived class. The class Circle inherits the attributes of the Shape class.
• The child class Circle overrides the methods and attributes of the base class (eg. draw() function defined in the base class Shape is overridden in child
class Circle).
# Examples of class
inheritance class Shape:
def init (self):
print "Base class constructor"
self.color = ’Green’
self.lineWeight = 10.0
def draw(self):
print "Draw - to be implemented"
def setColor(self, c):
self.color = c
def getColor(self):
return self.color
def setLineWeight(self,lwt):
self.lineWeight = lwt
def getLineWeight(self):
return self.lineWeight
class Circle(Shape):
def init (self, c,r):
print "Child class constructor"
self.center = c
self.radius = r
self.color = ’Green’
self.lineWeight = 10.0
self. label = ’Hidden circlelabel’
def setCenter(self,c):
self.center = c
def getCenter(self):
return self.center
def setRadius(self,r):
self.radius = r
def getRadius(self):
return self.radius
def draw(self):
print "Draw Circle (overridden function)"
class Point:
def init (self, x, y):
self.xCoordinate = x
self.yCoordinate = y
def setXCoordinate(self,x):
self.xCoordinate = x
def getXCoordinate(self):
return self.xCoordinate
def setYCoordinate(self,y):
self.yCoordinate = y
def getYCoordinate(self):
return self.yCoordinate
>>>p = Point(2,4)
>>>circ = Circle(p,7)
Child class constructor
>>>circ.getColor()
’Green’
>>>circ.setColor(’Red’)
>>>circ.getColor()
’Red’
>>>circ.getLineWeight()
10.0
>>>circ.getCenter().getXCoordinate()
2
>>>circ.getCenter().getYCoordinate()
4
>>>circ.draw()
Draw Circle (overridden function)
>>>circ.radius
7
Program execution process using IDLE
Numbers: This data type is used to store numeric values
Strings
Lists
Lists Contd..
Tuples
A tuple is a Sequence data type that is similar to that to the list.
Unlike lists, the elements of tuples cannot be changed, so tuples can be thought of as read-only lists.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
Dictionaries
Dictionary is a mapping data type or a kind of hash table that maps keys to values.
Keys in a dictionary can be of any data type, though numbers and strings are commonly used for keys
Contd..
Control Flow
The if statement in python is similar to the if statement of other languages.
for
Syntax: For iterating_var in sequence:
Execute Statements
While
While(condition is true):
Statements…
range
5. Break/Continue
The Break statement breaks out for/while loop where as continue statement continues with next iteration
Continue
Pass
The pass statement is used when statement is required syntactically but you do not want any command or code to
execute.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
Modules
Python allows organizing of the program code into different modules which improves the code readability and
management.
A module in python file defines some functionality in the form of functions or classes.
Modules can be imported using the import keyword.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
Package
A Directory that contains __init__.py is a package.
A Package is a Hierarchical file directory structure that defines a single python application environment that
consists of modules and sub packages and sub sub packages and soon.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
File Handling
Python allows reading and writing to files using the file object.
The open(filename, mode) function is used to get a file object.
The mode can be read(r),write(w),append(a),read binary(rb),write binary(wb),etc.,
After the file contents have been read the close () is called which closes the file object
Classes
Python is an object-oriented programming (oop) language.
Python provides all the standard features of Object Oriented Programming such as
classes
class variable
class methods
inheritance
function overloading and operator overloading
The simplest form of class definition looks like this:
Class Objects
Inheritance
JSON
JSON or JavaScript Object Notation is a lightweight text-based open standard
designed for human-readable data interchange. The JSON format was
originally specified by Douglas Crockford,. The official Internet media type for
JSON is application/json. The JSON filename extension is .json.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
JSON stands for JavaScript Object Notation.
The format was specified by Douglas Crockford.
It was designed for human-readable data interchange.
It has been extended from the JavaScript scripting language.
The filename extension is .json.
JSON Internet Media type is application/json.
The Uniform Type Identifier is public.json.
Uses of JSON
It is used while writing JavaScript based applications that includes
browser extensions and websites.
JSON format is used for serializing and transmitting structured data
over network connection.
It is primarily used to transmit data between a server and web
applications.
Web services and APIs use JSON format to provide public data.
It can be used with modern programming languages.
Simple Example in JSON
The following example shows how to use JSON to store information related to books based on their topic and edition.
"
The process of encoding JSON is usually called serialization. This term
refers to the transformation of data into a series of bytes (hence serial) to
be stored or transmitted across a network. You may also hear the
term marshaling, but that’s a whole other discussion.
Naturally, deserialization is the reciprocal process of decoding data that
has been stored or delivered in the JSON standard.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
A Simple Serialization Example
It is critical that you save this information to disk, so your mission is to write it to a file.
Using Python’s context manager, you can create a file called data_file.json and open it in write mode.
(JSON files conveniently end in a .json extension.)
BUILDING IoT WITH ARDUINO & RASPBERRY PI
BUILDING IoT WITH ARDUINO & RASPBERRY PI
Reading and Writing XML Files in Python
XML, or Extensible Markup Language, is a markup-language that is commonly used
to structure, store, and transfer data between systems.
With Python being a popular language for the web and data analysis, it's likely you'll
need to read or write XML data at some point.
Throughout this Class look at the ElementTree module for reading, writing, and
modifying XML data. We'll also compare it with the older minidom module in the
first few sections so you can get a good comparison of the two.
The XML Modules
The minidom, or Minimal DOM Implementation, is a simplified implementation of the Document
Object Model (DOM). The DOM is an application programming interface that treats XML as a tree
structure, where each node in the tree is an object. Thus, the use of this module requires that we are
familiar with its functionality.
The ElementTree module provides a more "Pythonic" interface to handling XMl and is a good option
for those not familiar with the DOM.
XML File Example
In the examples below, we will be using the following XML file, which we will save as "items.xml":
As you can see, it's a fairly simple XML example, only containing a few nested
objects and one attribute.
Reading XML Documents
Using minidom
In order to parse an XML document using minidom, we must first import it from
the xml.dom module. This module uses the parse function to create a DOM object from our XML
file. The parse function has the following syntax:
xml.dom.minidom.parse (filename_or_file[,parser[, bufsize]])
Here the file name can be a string containing the file path or a file-type object. The function returns
a document, which can be handled as an XML type. Thus, we can use the
function getElementByTagName() to find a specific tag.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
If we wanted to use an already-opened file, can just pass our file object to parse like so:
Using ElementTree
ElementTree presents us with an very simple way to process XML files. As always, in order to use
it we must first import the module. In our code we use the import command with the as keyword,
which allows us to use a simplified name (ET in this case) for the module in the code.
Following the import, we create a tree structure with the parse function, and we obtain its root
element.
Once we have access to the root node we can easily traverse around the tree, because a tree is a
connected graph.
BUILDING IoT WITH ARDUINO & RASPBERRY PI
Working Code
import xml.etree.ElementTree as xml
def GenerateXML(FileName):
root = xml.Element("Customers")
c1 = xml.Element("Customer type")
c1.text ="Business"
root.append(c1)
type1 = xml.SubElement(c1,"Place")
type1.text = "UK"
amount1 = xml.SubElement(c1,"Amount")
amount1.text = "15000"
tree = xml.ElementTree(root)
with open(FileName,'wb') as files:
tree.write(files)
if __name__=="__main__":
GenerateXML("Customer4.xml")

More Related Content

PPTX
IoT Heaps 4
PDF
Programming RPi for IoT Applications.pdf
PPTX
FIot_Unit-3 fundAMENTALS OF IOT BASICS.pptx
PPTX
Programming
PPTX
Python-The programming Language
PDF
Chapter-6.pdf
PDF
Chapter 6
PPTX
Python programming basic Presentation.pptx
IoT Heaps 4
Programming RPi for IoT Applications.pdf
FIot_Unit-3 fundAMENTALS OF IOT BASICS.pptx
Programming
Python-The programming Language
Chapter-6.pdf
Chapter 6
Python programming basic Presentation.pptx

Similar to BUILDING IoT WITH ARDUINO & RASPBERRY PI (20)

PPTX
PYTHON INTERNSHIP PPT download free.pptx
PDF
Introduction to python
PPTX
python presntation 2.pptx
PPTX
python_module_.................................................................
PPTX
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
PDF
Python indroduction
 
PPTX
2024-25 TYBSC(CS)-PYTHON_PROG_ControlStructure.pptx
PPTX
Integrating Python with SQL (12345).pptx
PPTX
Python- Basic. pptx with lists, tuples dictionaries and data types
PPTX
Python- Basic.pptx with data types, lists, and tuples with dictionary
PPTX
Python Conditional and Looping statements.pptx
PDF
To get the notes of python of MCA batchs
PPTX
Introduction to Programming.pptx ok ok ok
PPTX
PPTX
Introduction_to_Python_Presentation.pptx
PPTX
Introduction_to_Python_Presentation.pptx
PPTX
python programming unit 1 wala ppt .pptx
PDF
ppt_pspp.pdf
PPTX
2. Getting Started with Python second lesson .pptx
PPTX
Datatypes python programming
PYTHON INTERNSHIP PPT download free.pptx
Introduction to python
python presntation 2.pptx
python_module_.................................................................
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
Python indroduction
 
2024-25 TYBSC(CS)-PYTHON_PROG_ControlStructure.pptx
Integrating Python with SQL (12345).pptx
Python- Basic. pptx with lists, tuples dictionaries and data types
Python- Basic.pptx with data types, lists, and tuples with dictionary
Python Conditional and Looping statements.pptx
To get the notes of python of MCA batchs
Introduction to Programming.pptx ok ok ok
Introduction_to_Python_Presentation.pptx
Introduction_to_Python_Presentation.pptx
python programming unit 1 wala ppt .pptx
ppt_pspp.pdf
2. Getting Started with Python second lesson .pptx
Datatypes python programming
Ad

Recently uploaded (20)

PDF
Microsoft Teams Essentials; The pricing and the versions_PDF.pdf
PPTX
Save Business Costs with CRM Software for Insurance Agents
PPTX
What to Capture When It Breaks: 16 Artifacts That Reveal Root Causes
PDF
Best Mobile App Development Company in Lucknow - Code Crafter Web Solutions
PPTX
Odoo Consulting Services by CandidRoot Solutions
PDF
ShowUs: Pharo Stream Deck (ESUG 2025, Gdansk)
PDF
Jenkins: An open-source automation server powering CI/CD Automation
PPTX
Materi_Pemrograman_Komputer-Looping.pptx
PPTX
Maximizing Revenue with Marketo Measure: A Deep Dive into Multi-Touch Attribu...
PPTX
Benefits of DCCM for Genesys Contact Center
PDF
Comprehensive Salesforce Implementation Services.pdf
PDF
IEEE-CS Tech Predictions, SWEBOK and Quantum Software: Towards Q-SWEBOK
PDF
Convert Thunderbird to Outlook into bulk
PDF
Sensix-Tech-Pvt-Ltd-Company-Profile (1).pdf
PDF
Multi-factor Authentication (MFA) requirement for Microsoft 365 Admin Center_...
PPTX
Presentation of Computer CLASS 2 .pptx
PDF
PTS Company Brochure 2025 (1).pdf.......
PDF
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
PDF
The Role of Automation and AI in EHS Management for Data Centers.pdf
PPTX
Services offered by Dynamic Solutions in Pakistan
Microsoft Teams Essentials; The pricing and the versions_PDF.pdf
Save Business Costs with CRM Software for Insurance Agents
What to Capture When It Breaks: 16 Artifacts That Reveal Root Causes
Best Mobile App Development Company in Lucknow - Code Crafter Web Solutions
Odoo Consulting Services by CandidRoot Solutions
ShowUs: Pharo Stream Deck (ESUG 2025, Gdansk)
Jenkins: An open-source automation server powering CI/CD Automation
Materi_Pemrograman_Komputer-Looping.pptx
Maximizing Revenue with Marketo Measure: A Deep Dive into Multi-Touch Attribu...
Benefits of DCCM for Genesys Contact Center
Comprehensive Salesforce Implementation Services.pdf
IEEE-CS Tech Predictions, SWEBOK and Quantum Software: Towards Q-SWEBOK
Convert Thunderbird to Outlook into bulk
Sensix-Tech-Pvt-Ltd-Company-Profile (1).pdf
Multi-factor Authentication (MFA) requirement for Microsoft 365 Admin Center_...
Presentation of Computer CLASS 2 .pptx
PTS Company Brochure 2025 (1).pdf.......
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
The Role of Automation and AI in EHS Management for Data Centers.pdf
Services offered by Dynamic Solutions in Pakistan
Ad

BUILDING IoT WITH ARDUINO & RASPBERRY PI

  • 1. UNIT-II IoT Systems – Logical Design using Python
  • 2. Outline • Introduction to Python • Installing Python • Python Data Types & Data Structures • Control Flow • Functions • Modules • Packages • File Input/Output • Date/Time Operations • Classes
  • 3. Python • Python is a general-purpose high level programming language and suitable for providing a solid foundation to the reader in the area of cloud computing. • The main characteristics of Python are: • Multi-paradigm programming language • Python supports more than one programming paradigms including object-oriented programming and structured programming • Interpreted Language • Python is an interpreted language and does not require an explicit compilation step. The Python interpreter executes the program source code directly, statement by statement, as a processor or scripting engine does. • Interactive Language • Python provides an interactive mode in which the user can submit commands at the Python prompt and interact with the interpreter directly.
  • 4. Python - Benefits • Easy-to-learn, read and maintain • Python is a minimalistic language with relatively few keywords, uses English keywords and has fewer syntactical constructions as compared to other languages. Reading Python programs feels like English with pseudo-code like constructs. Python is easy to learn yet an extremely powerful language for a wide range of applications. • Object and Procedure Oriented • Python supports both procedure-oriented programming and object-oriented programming. Procedure oriented paradigm allows programs to be written around procedures or functions that allow reuse of code. Procedure oriented paradigm allows programs to be written around objects that include both data and functionality. • Extendable • Python is an extendable language and allows integration of low-level modules written in languages such as C/C++. This is useful when you want to speed up a critical portion of a program. • Scalable • Due to the minimalistic nature of Python, it provides a manageable structure for large programs. • Portable • Since Python is an interpreted language, programmers do not have to worry about compilation, linking and loading of programs. Python programs can be directly executed from source • Broad Library Support • Python has a broad library support and works on various platforms such as Windows, Linux, Mac, etc.
  • 5. Python - Setup • Windows • Python binaries for Windows can be downloaded from http://www.python.org/getit . • For the examples and exercise in this book, you would require Python 2.7 which can be directly downloaded from: http://www.python.org/ftp/python/2.7.5/python-2.7.5.msi • Once the python binary is installed you can run the python shell at the command prompt using > python • Linux #Install Dependencies sudo apt-get install build-essential sudo apt-get install libreadline-gplv2-dev libncursesw5-dev libssl-dev libsqlite3-dev tk-dev libgdbm-dev libc6-dev libbz2-dev #Download Python wget http://python.org/ftp/python/2.7.5/Python-2.7.5.tgz tar -xvf Python-2.7.5.tgz cd Python-2.7.5 #Install Python ./configure make sudo make install
  • 6. Numbers • Numbers • Number data type is used to store numeric values. Numbers are immutable data types, therefore changing the value of a number data type results in a newly allocated object. #Integer >>>a=5 >>>type(a) <type ’int’> #Floating Point >>>b=2.5 >>>type(b) <type ’float’> #Long >>>x=9898878787676 L >>>type(x) <type ’long’> #Complex >>>y=2+5j >>>y (2+5j ) >>>type(y) <type ’complex’> >>>y.rea l 2 >>>y.ima g 5 #Addition >>>c=a+b >>> c 7.5 >>>type(c) <type ’float’> #Subtraction >>>d=a-b >>> d 2.5 >>>type(d) <type ’float’> #Multiplicatio n >>>e=a*b >>> e 12.5 >>>type(e) <type ’float’> #Division >>>f=b/a >>> f 0.5 >>>type(f) <type float’> #Power >>>g=a** 2 >>> g 25
  • 7. Strings • Strings • A string is simply a list of characters in order. There are no limits to the number of characters you can have in a string. #Create string >>>s="Hello World!" >>>type(s) <type ’str’> #String concatenation >>>t="This is sample program." >>>r = s+t >>>r ’Hello World!This is sample program.’ #Get length of string >>>len(s ) 12 #Convert string to integer >>>x="100" >>>type(s) <type ’str’> >>>y=int(x) >>> y 100 #Print string >>>print s Hello World! #Formatting output >>>print "The string (The string (Hello World!) has 12 characters #Convert to upper/lower case >>>s.upper() ’HELLO WORLD!’ >>>s.lower() ’hello world!’ #Accessing sub-strings >>>s[0 ] ’H’ >>>s[6:] ’World!’ >>>s[6:-1] ’World’ #strip: Returns a copy of the string with the #leading and trailing characters removed. >>>s.strip("!" ) ’Hello World’
  • 8. Lists • Lists • List a compound data type used to group together other values. List items need not all have the same type. A list contains items separated by commas and enclosed within square brackets. #Create List >>>fruits=[’apple’,’orange’,’banana’,’mango’] >>>type(fruits) <type ’list’> #Get Length of List >>>len(fruits ) 4 #Access List Elements >>>fruits[1 ] ’orange’ >>>fruits[1:3] [’orange’, ’banana’] >>>fruits[1:] [’orange’, ’banana’, ’mango’] #Appending an item to a list >>>fruits.append(’pear’) >>>fruits [’apple’, ’orange’, ’banana’, ’mango’, ’pear’] #Removing an item from a list >>>fruits.remove(’mango’) >>>fruits [’apple’, ’orange’, ’banana’, ’pear’] #Inserting an item to a list >>>fruits.insert(1,’mango’) >>>fruits [’apple’, ’mango’, ’orange’, ’banana’, ’pear’] #Combining lists >>>vegetables=[’potato’,’carrot’,’onion’,’beans’,’ r adish’] >>>vegetables [’potato’, ’carrot’, ’onion’, ’beans’, ’radish’] >>>eatables=fruits+vegetables >>>eatables [’appl e’, ’mang o’, ’orang e’, ’banan a’, ’pear’, ’potato’, ’carrot’, ’onion’, ’beans’, ’radish’] #Mixed data types in a list >>>mixed=[’data’,5,100.1,8287398L] >>>type(mixed) <type ’list’> >>>type(mixed[0]) <type ’str’> >>>type(mixed[1]) <type ’int’> >>>type(mixed[2]) <type ’float’> >>>type(mixed[3]) <type ’long’> #Change individual elements of a list >>>mixed[0]=mixed[0]+" items" >>>mixed[1]=mixed[1]+1 >>>mixed[2]=mixed[2]+0.05 >>>mixed [’data items’, 6, 100.14999999999999, 8287398L] #Lists can be nested >>>nested=[fruits,vegetables] >>>nested [[’apple’, ’mango’, ’orange’, ’banana’, ’pear’], [’potato’, ’carrot’, ’onion’, ’beans’, ’radish’]]
  • 9. Tuples • Tuples • A tuple is a sequence data type that is similar to the list. A tuple consists of a number of values separated by commas and enclosed within parentheses. Unlike lists, the elements of tuples cannot be changed, so tuples can be thought of as read-only lists. #Create a Tuple >>>fruits=("apple","mango","banana","pineapple") >>>fruits (’apple’, ’mango’, ’banana’, ’pineapple’) >>>type(fruits) <type ’tuple’> #Get length of tuple >>>len(fruits ) 4 #Get an element from a tuple >>>fruits[0 ] ’apple’ >>>fruits[:2] (’apple’, ’mango’) #Combining tuples >>>vegetables=(’potato’,’carrot’,’onion’,’radish’) >>>eatables=fruits+vegetables >>>eatables (’apple’, ’mango’, ’banana’, ’pineapple’, ’potato’, ’carrot’, ’onion’, ’radish’)
  • 10. Dictionaries • Dictionaries • Dictionary is a mapping data type or a kind of hash table that maps keys to values. Keys in a dictionary can be of any data type, though numbers and strings are commonly used for keys. Values in a dictionary can be any data type or object. #Create a dictionary >>>student={’name’:’Mary’,’id’:’8776’,’major’:’CS’} >>>student {’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’} >>>type(student) <type ’dict’> #Get length of a dictionary >>>len(student) 3 #Get the value of a key in dictionary >>>student[’name’] ’Mary’ #Get all items in a dictionary >>>student.items() [(’gender’, ’female’), (’major’, ’CS’), (’name’, ’Mary’), (’id’, ’8776’)] #Get all keys in a dictionary >>>student.keys() [’gender’, ’major’, ’name’, ’id’] #Get all values in a dictionary >>>student.values() [’female’, ’CS’, ’Mary’, ’8776’] #Add new key-value pair >>>student[’gender’]=’female’ >>>student {’gende r’: ’female’, ’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’} #A value in a dictionary can be another dictionary >>>student1={’name’:’David’,’id’:’9876’,’major’:’ECE’} >>>students={’1’: student,’2’:student1} >>>students {’1’: {’gende r’: ’female’, ’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’}, ’2’: { ’ major’: ’ECE’, ’name’: ’David’, ’id’: ’9876’}} #Check if dictionary has a key >>>student.has_key(’name’) True >>>student.has_key(’grade’) False
  • 11. Type Conversions #Convert to string >>>a=10000 >>>str(a ) ’10000’ #Convert to int >>>b="2013" >>>int(b ) 2013 #Convert to float >>>float(b ) 2013.0 #Convert to long >>>long(b ) 2013L #Convert to list >>>s="aeiou" >>>list(s) [’a’, ’e’, ’i’, ’o’, ’u’] #Convert to set >>>x=[’mango’,’apple’,’banana’,’mango’,’banana’] >>>set(x) set([’mango’, ’apple’, ’banana’]) • Type conversion examples
  • 12. Control Flow – if statement • The if statement in Python is similar to the if statement in other languages. >>>a = 25**5 >>>if a>10000: print "More" else: print "Less" More >>>s="Hello World" >>>if "World" in s: s=s+"!" print s Hello World! >>>if a>10000: if a<1000000: print "Between 10k and 100k" else: print "More than 100k" elif a==10000: print "Equal to 10k" else: print "Less than 10k" More than 100k >>>student={’name’:’Mary’,’id’:’8776’} >>>if not student.has_key(’major’): student[’major’]=’CS’ >>>student {’major’: ’CS’, ’name’: ’Mary’, ’id’: ’8776’}
  • 13. Control Flow – for statement • The for statement in Python iterates over items of any sequence (list, string, etc.) in the order in which they appear in the sequence. • This behavior is different from the for statement in other languages such as C in which an initialization, incrementing and stopping criteria are provided.
  • 14. for Syntax: For iterating_var in sequence: Execute Statements
  • 15. Control Flow – while statement • The while statement in Python executes the statements within the while loop as long as the while condition is true. #Prints even numbers upto 100 >>> i = 0 >>> while i<=100: if i%2 == 0: printi i = i+1
  • 16. Control Flow – range statement • The range statement in Python generates a list of numbers in arithmetic progression. #Generate a list of numbers from 10 - 100 with increments of 10 >>>range(10,110,10) [10, 20, 30, 40, 50, 60, 70, 80, 90,100] #Generate a list of numbers from 0 – 9 >>>range (10) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
  • 17. Control Flow – break/continue statements • The break and continue statements in Python are similar to the statements in C. • Break • Break statement breaks out of the for/while loop • Continue • Continue statement continues with the next iteration. #Continue statement example >>>fruits=[’apple’,’orange’,’banana’,’mango’] >>>for item in fruits: if item == "banana": continue else: print item apple orange mango #Break statement example >>>y=1 >>>for x in range(4,256,4): y = y * x if y > 512: break print y 4 32 384
  • 18. Control Flow – pass statement • The pass statement in Python is a null operation. • The pass statement is used when a statement is required syntactically but you do not want any command or code to execute. >fruits=[’apple’,’orange’,’banana’,’mango’] >for item in fruits: if item == "banana": pass else: print item apple orange mango
  • 19. Functions • A function is a block of code that takes information in (in the form of parameters), does some computation, and returns a new piece of information based on the parameter information. • A function in Python is a block of code that begins with the keyword def followed by the function name and parentheses. The function parameters are enclosed within the parenthesis. • The code block within a function begins after a colon that comes after the parenthesis enclosing the parameters. • The first statement of the function body can optionally be a documentation string or docstring. students = { '1': {'name': 'Bob', 'grade': 2.5}, '2': {'name': 'Mary', 'grade': 3.5}, '3': {'name': 'David', 'grade': 4.2}, '4': {'name': 'John', 'grade': 4.1}, '5': {'name': 'Alex', 'grade': 3.8}} def averageGrade(students): “This function computes the average grade” sum = 0.0 for key in students: sum = sum + students[key]['grade'] average = sum/len(students) return average avg = averageGrade(students) print (The average garde is: %0.2f" % (avg)))
  • 20. Functions-Default Arguments • Functions can have default values of the parameters. • If a function with default values is called with fewer parameters or without any parameter, the default values of the parameters are used >>>def displayFruits(fruits=[’apple’,’orange’]): print "There are %d fruits in the list" % (len(fruits)) for item in fruits: print item #Using default arguments >>>displayFruits( ) apple orange >>>fruits = [’banana’, ’pear’, ’mango’] >>>displayFruits(fruits ) banana pear mango
  • 21. Functions-Passing by Reference • All parameters in the Python functions are passed by reference. • If a parameter is changed within a function the change also reflected back in the calling function. >>>def displayFruits(fruits): print "There are %d fruits in the list" % (len(fruits)) for item in fruits: print item print "Adding one more fruit" fruits.append('mango') >>>fruits = ['banana', 'pear', 'apple'] >>>displayFruits(fruits) There are 3 fruits in the list banana pear apple #Adding one more fruit >>>print "There are %d fruits in the list" % (len(fruits)) There are 4 fruits in the list
  • 22. Functions - Keyword Arguments • Functions can also be called using keyword arguments that identifies the arguments by the parameter name when the function is called. >>>def printStudentRecords(name,age=20,major=’CS’): print "Name: " + name print "Age: " + str(age) print "Major: " + major #This will give error as name is required argument >>>printStudentRecords() Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: printStudentRecords() takes at least 1 argument (0 given) #name is a formal argument. #**kwargs is a keyword argument that receives all arguments except the formal argument as a dictionary. >>>def student(name, **kwargs): print "Student Name: " + name for key in kwargs: print key + ’: ’ + kwargs[key] >>>student(name=’Bob’, age=’20’, major = ’CS’) Student Name: Bob age: 20 major: CS #Correct use >>>printStudentRecords(name=’Alex’ ) Name: Alex Age: 20 Major: CS >>>printStudentRecords(name=’Bob’,age=22,major=’E C E’) Name: Bob Age: 22 Major: ECE >>>printStudentRecords(name=’Alan’,major=’ECE’) Name: Alan Age: 20 Major: ECE
  • 23. Functions - Variable Length Arguments • Python functions can have variable length arguments. The variable length arguments are passed to as a tuple to the function with an argument prefixed with asterix (*) >>>def student(name, *varargs): print "Student Name: " + name for item in varargs: print item >>>student(’Nav’) Student Name: Nav >>>student(’Amy’, ’Age: 24’) Student Name: Amy Age: 24 >>>student(’Bob’, ’Age: 20’, ’Major: CS’) Student Name: Bob Age: 20 Major: CS
  • 24. Modules • Python allows organizing the program code into different modules which improves the code readability and management. • A module is a Python file that defines some functionality in the form of functions or classes. • Modules can be imported using the import keyword. • Modules to be imported must be present in the search path. #student module - saved as student.py def averageGrade(students): sum = 0.0 for key in students: sum = sum + students[key]['grade'] average = sum/len(students) return average def printRecords(students): print "There are %d students" %(len(students)) i=1 for key in students: print "Student-%d: " % (i) print "Name: " + students[key]['name'] print "Grade: " + str(students[key]['grade']) i = i+1 #Using student module >>>import student >>>students = '1': 'name': 'Bob', 'grade': 2.5, '2': 'name': 'Mary', 'grade': 3.5, '3': 'name': 'David', 'grade': 4.2, '4': 'name': 'John', 'grade': 4.1, '5': 'name': 'Alex', 'grade': 3.8 >>>student.printRecords(students) There are 5 students Student-1: Name: Bob Grade: 2.5 Student-2: Name: David Grade: 4.2 Student- 3: Name: Mary Grade: 3.5 Student-4: Name: Alex Grade: 3.8 Student-5: Name: John Grade: 4.1 >>>avg = student. averageGrade(students) >>>print "The average garde is: %0.2f" % (avg) 3.62 # Importing a specific function from a module >>>from student import averageGrade # Listing all names defines in a module >>>dir(student)
  • 25. Packages • Python package is hierarchical file structure that consists of modules and subpackages. • Packages allow better organization of modules related to a single application environment. # skimage package listing skimage/ init .py Top level package Treat directory as a package color/ color color subpackage init .py colorconv.py colorlabel.py rgb_colors.py draw/ draw draw subpackage init .py draw.py setup.py exposure/ exposure subpackage init .py _adapthist.py exposure.py feature/ feature subpackage init .py _brief.py _daisy.py ...
  • 26. File Handling • Python allows reading and writing to files using the file object. • The open(filename, mode) function is used to get a file object. • The mode can be read (r), write (w), append (a), read and write (r+ or w+), read-binary (rb), write-binary (wb), etc. • After the file contents have been read the close function is called which closes the file object. # Example of reading line by line >>>fp = open('file1.txt','r') >>>print "Line-1: " + fp.readline() Line-1: Python supports more than one programming paradigms. >>>print "Line-2: " + fp.readline() Line-2: Python is an interpreted language. >>>fp.close() # Example of reading an entire file >>>fp = open('file.txt','r') >>>content = fp.read() >>>print content This is a test file. >>>fp.close() # Example of reading lines in a loop >>>fp = open(’file1.txt’,’r’) >>>lines = fp.readlines() >>>for line in lines: print line Python supports more than one programming paradigms. Python is an interpreted language.
  • 27. File Handling # Example of seeking to a certain position >>>fp = open('file.txt','r') >>>fp.seek(10,0) >>>content = fp.read(10) >>>print content ports more >>>fp.close() # Example of reading a certain number of bytes >>>fp = open('file.txt','r') >>>fp.read(10 ) 'Python sup' >>>fp.close() # Example of getting the current position of read >>>fp = open('file.txt','r') >>>fp.read(10 ) 'Python sup' >>>currentpos = fp.tell >>>print currentpos <built-in method tell of file object at 0x0000000002391390> >>>fp.close() # Example of writing to a file >>>fo = open('file1.txt','w') >>>content='This is an example of writing to a file in Python.' >>>fo.write(content) >>>fo.close()
  • 28. Date/Time Operations • Python provides several functions for date and time access and conversions. • The datetime module allows manipulating date and time in several ways. • The time module in Python provides various time-related functions. # Examples of manipulating with date >>>from datetime import date >>>now = date.today() >>>print "Date: " + now.strftime("%m-%d- %y") Date: 07-24-13 >>>print "Day of Week: " + now.strftime("%A") Day of Week: Wednesday >>>print "Month: " + now.strftime("%B") Month: July >>>then = date(2013, 6, 7) >>>timediff = now - then >>>timediff.day s 47 # Examples of manipulating with time >>>import time >>>nowtime = time.time() >>>time.localtime(nowtime) time.struct_time(tm_year=2013, tm_mon=7, tm_mday=24, tm_ec=51, tm_wday=2, tm_yday=205, tm_isdst=0) >>>time.asctime(time.localtime(nowtime)) 'Wed Jul 24 16:14:51 2013' >>>time.strftime("The date is %d-%m-%y. Today is a %A. It is %H hours, %M minutes and %S seconds now.") 'The date is 24-07-13. Today is a Wednesday. It is 16 hours, 15 minutes and 14 seconds now.'
  • 29. Classes • Python is an Object-Oriented Programming (OOP) language. Python provides all the standard features of Object Oriented Programming such as classes, class variables, class methods, inheritance, function overloading, and operator overloading. • Class • A class is simply a representation of a type of object and user-defined prototype for an object that is composed of three things: a name, attributes, and operations/methods. • Instance/Object • Object is an instance of the data structure defined by a class. • Inheritance • Inheritance is the process of forming a new class from an existing class or base class. • Function overloading • Function overloading is a form of polymorphism that allows a function to have different meanings, depending on its context. • Operator overloading • Operator overloading is a form of polymorphism that allows assignment of more than one function to a particular operator. • Function overriding • Function overriding allows a child class to provide a specific implementation of a function that is already provided by the base class. Child class implementation of the overridden function has the same name, parameters and return type as the function in the base class.
  • 30. Class Example • The variable studentCount is a class variable that is shared by all instances of the class Student and is accessed by Student.studentCount. • The variables name, id and grades are instance variables which are specific to each instance of the class. • There is a special method by the name init () which is the class constructor. • The class constructor initializes a new instance when it is created. The function del () is the class destructor # Examples of a class class Student: studentCount = 0 def init (self, name, id): print "Constructor called" self.name = name self.id = id Student.studentCount = Student.studentCount + 1 self.grades={} def del (self): print "Destructor called" def getStudentCount(self): return Student.studentCount def addGrade(self,key,value): self.grades[key]=value def getGrade(self,key): return self.grades[key] def printGrades(self): for key in self.grades: print key + ": " + self.grades[key] >>>s = Student(’Steve’,’98928’) Constructor called >>>s.addGrade(’Math’,’90’) >>>s.addGrade(’Physics’,’85’) >>>s.printGrades() Physics: 85 Math: 90 >>>mathgrade = s.getGrade(’Math’) >>>print mathgrade 90 >>>count = s.getStudentCount() >>>print count 1 >>>del s Destructor called
  • 31. Class Inheritance • In this example Shape is the base class and Circle is the derived class. The class Circle inherits the attributes of the Shape class. • The child class Circle overrides the methods and attributes of the base class (eg. draw() function defined in the base class Shape is overridden in child class Circle). # Examples of class inheritance class Shape: def init (self): print "Base class constructor" self.color = ’Green’ self.lineWeight = 10.0 def draw(self): print "Draw - to be implemented" def setColor(self, c): self.color = c def getColor(self): return self.color def setLineWeight(self,lwt): self.lineWeight = lwt def getLineWeight(self): return self.lineWeight class Circle(Shape): def init (self, c,r): print "Child class constructor" self.center = c self.radius = r self.color = ’Green’ self.lineWeight = 10.0 self. label = ’Hidden circlelabel’ def setCenter(self,c): self.center = c def getCenter(self): return self.center def setRadius(self,r): self.radius = r def getRadius(self): return self.radius def draw(self): print "Draw Circle (overridden function)" class Point: def init (self, x, y): self.xCoordinate = x self.yCoordinate = y def setXCoordinate(self,x): self.xCoordinate = x def getXCoordinate(self): return self.xCoordinate def setYCoordinate(self,y): self.yCoordinate = y def getYCoordinate(self): return self.yCoordinate >>>p = Point(2,4) >>>circ = Circle(p,7) Child class constructor >>>circ.getColor() ’Green’ >>>circ.setColor(’Red’) >>>circ.getColor() ’Red’ >>>circ.getLineWeight() 10.0 >>>circ.getCenter().getXCoordinate() 2 >>>circ.getCenter().getYCoordinate() 4 >>>circ.draw() Draw Circle (overridden function) >>>circ.radius 7
  • 33. Numbers: This data type is used to store numeric values
  • 35. Lists
  • 37. Tuples A tuple is a Sequence data type that is similar to that to the list. Unlike lists, the elements of tuples cannot be changed, so tuples can be thought of as read-only lists.
  • 39. Dictionaries Dictionary is a mapping data type or a kind of hash table that maps keys to values. Keys in a dictionary can be of any data type, though numbers and strings are commonly used for keys
  • 41. Control Flow The if statement in python is similar to the if statement of other languages.
  • 42. for Syntax: For iterating_var in sequence: Execute Statements
  • 44. range
  • 45. 5. Break/Continue The Break statement breaks out for/while loop where as continue statement continues with next iteration
  • 47. Pass The pass statement is used when statement is required syntactically but you do not want any command or code to execute.
  • 49. Modules Python allows organizing of the program code into different modules which improves the code readability and management. A module in python file defines some functionality in the form of functions or classes. Modules can be imported using the import keyword.
  • 51. Package A Directory that contains __init__.py is a package. A Package is a Hierarchical file directory structure that defines a single python application environment that consists of modules and sub packages and sub sub packages and soon.
  • 53. File Handling Python allows reading and writing to files using the file object. The open(filename, mode) function is used to get a file object. The mode can be read(r),write(w),append(a),read binary(rb),write binary(wb),etc., After the file contents have been read the close () is called which closes the file object
  • 54. Classes Python is an object-oriented programming (oop) language. Python provides all the standard features of Object Oriented Programming such as classes class variable class methods inheritance function overloading and operator overloading
  • 55. The simplest form of class definition looks like this:
  • 58. JSON JSON or JavaScript Object Notation is a lightweight text-based open standard designed for human-readable data interchange. The JSON format was originally specified by Douglas Crockford,. The official Internet media type for JSON is application/json. The JSON filename extension is .json.
  • 60. JSON stands for JavaScript Object Notation. The format was specified by Douglas Crockford. It was designed for human-readable data interchange. It has been extended from the JavaScript scripting language. The filename extension is .json. JSON Internet Media type is application/json. The Uniform Type Identifier is public.json.
  • 61. Uses of JSON It is used while writing JavaScript based applications that includes browser extensions and websites. JSON format is used for serializing and transmitting structured data over network connection. It is primarily used to transmit data between a server and web applications. Web services and APIs use JSON format to provide public data. It can be used with modern programming languages.
  • 62. Simple Example in JSON The following example shows how to use JSON to store information related to books based on their topic and edition. "
  • 63. The process of encoding JSON is usually called serialization. This term refers to the transformation of data into a series of bytes (hence serial) to be stored or transmitted across a network. You may also hear the term marshaling, but that’s a whole other discussion. Naturally, deserialization is the reciprocal process of decoding data that has been stored or delivered in the JSON standard.
  • 66. It is critical that you save this information to disk, so your mission is to write it to a file. Using Python’s context manager, you can create a file called data_file.json and open it in write mode. (JSON files conveniently end in a .json extension.)
  • 69. Reading and Writing XML Files in Python XML, or Extensible Markup Language, is a markup-language that is commonly used to structure, store, and transfer data between systems. With Python being a popular language for the web and data analysis, it's likely you'll need to read or write XML data at some point. Throughout this Class look at the ElementTree module for reading, writing, and modifying XML data. We'll also compare it with the older minidom module in the first few sections so you can get a good comparison of the two.
  • 70. The XML Modules The minidom, or Minimal DOM Implementation, is a simplified implementation of the Document Object Model (DOM). The DOM is an application programming interface that treats XML as a tree structure, where each node in the tree is an object. Thus, the use of this module requires that we are familiar with its functionality. The ElementTree module provides a more "Pythonic" interface to handling XMl and is a good option for those not familiar with the DOM.
  • 72. In the examples below, we will be using the following XML file, which we will save as "items.xml": As you can see, it's a fairly simple XML example, only containing a few nested objects and one attribute.
  • 73. Reading XML Documents Using minidom In order to parse an XML document using minidom, we must first import it from the xml.dom module. This module uses the parse function to create a DOM object from our XML file. The parse function has the following syntax: xml.dom.minidom.parse (filename_or_file[,parser[, bufsize]])
  • 74. Here the file name can be a string containing the file path or a file-type object. The function returns a document, which can be handled as an XML type. Thus, we can use the function getElementByTagName() to find a specific tag.
  • 76. If we wanted to use an already-opened file, can just pass our file object to parse like so:
  • 77. Using ElementTree ElementTree presents us with an very simple way to process XML files. As always, in order to use it we must first import the module. In our code we use the import command with the as keyword, which allows us to use a simplified name (ET in this case) for the module in the code. Following the import, we create a tree structure with the parse function, and we obtain its root element. Once we have access to the root node we can easily traverse around the tree, because a tree is a connected graph.
  • 79. Working Code import xml.etree.ElementTree as xml def GenerateXML(FileName): root = xml.Element("Customers") c1 = xml.Element("Customer type") c1.text ="Business" root.append(c1) type1 = xml.SubElement(c1,"Place") type1.text = "UK" amount1 = xml.SubElement(c1,"Amount") amount1.text = "15000" tree = xml.ElementTree(root) with open(FileName,'wb') as files: tree.write(files) if __name__=="__main__": GenerateXML("Customer4.xml")