Tuesday, September 27, 2022

DE Series -2

2. Python for Data Engineering

I am going to cover this topic with 3 parts. The ay are follows

Part :1  Basic Python 

Part: 2 Advance Python

Part: 3 Writing  optimized code 

In this post we are to see part 1: Basic Python. We will be covering below Python topics in detail with hands on coding exercise —

1. Data types, strings, operators, and Chaining Comparison Operators with Logical Operators
2. Python Lists and Dictionaries, Sets, Tuples
3. Loops, Break and Continue Statements
4. Object-Oriented Programming — Class and attributes
5. Python strings in detail
6. Python F-String
7. Map, Classes, Functions and Arguments
8. First Class functions, Private Variables, Global and Non Local Variables, __import__ function
9. Magic Functions, Tuple Unpacking
10. Static Variables and Methods in Python
11. Lambda Functions, Magic methods
12. Inheritance and Polymorphism, Errors and Exception Handling
13. User-defined functions, Python garbage collection, debugger in Python
14. Iterators, Generators, and Decorators, Memoization using Decorators
15. Ordered and Defaultdict, Coroutine
16. Regular expression, Magic methods, Closures
17. ChainMap
18. Python Itertools
19. Advanced python constructs
20. Comprehensions, Named Tuple, Type hinting in Python
21. How to write efficient Code in Python
22. Efficient Code and Optimization techniques for Python

Python is a high-level, most widely used multi-purpose, easy to read programming language.

It is —

  • Interpreted − Python is processed at runtime by the interpreter. i.e you do not need to compile your program before executing it.
  • Interactive − You can interact with the interpreter directly to write your program.
  • Portable — It can run on wide range of hardware Platforms.
  • Object-Oriented − Python supports Object-Oriented style and Procedural Paradigm.
  • Used as a scripting language or can be compiled to byte-code for building large applications.
  • It has simple structure, and a clearly defined syntax.
  • Known as Beginner’s Language − It’s a great language for the beginner-level programmers.
  • Source code is comparatively easy-to-maintain.
  • Provides very high-level dynamic data types and supports dynamic type checking.
  • Has a huge collection of standard library

Popular applications for Python:\

  • Web Development.
  • Data Science — including machine learning, data analysis, and data visualization
  • Scripting
  • Game Development
  • CAD Applications
  • Embedded Applications

Python Data Types

Data Types represent the kind of value variables can hold and what all operations can be performed on a particular data.


Implementation —

#Int data Type

var = 5
print(var)
print(type(var))

Output —

5
<class 'int'>

Implementation —

#Float data type

var2 = 0.1234
print(var2)
print(type(var2))

Output —

0.1234
<class 'float'>

Implementation —

#Complex numbers data type

x = 2j
print(x)
print(type(x))

Output —

2j
<class 'complex'>

Implementation —

#String Data Type

str_one = "Hello World"

print(str_one)
print(type(str_one))

Output —

Hello World
<class 'str'>

Implementation —

#list Data type

list1 = ["car","bike"]
print(list1)
print(type(list1))

Output —

['car', 'bike']
<class 'list'>

Implementation —

#Tuple Data Type

tup= ("car","bike","bus")
print(tup)
print(type(tup))

Output —

('car', 'bike', 'bus')
<class 'tuple'>

Implementation —

#Dictionary Data type

dict_one = {"Name": "Steve", "Location": "NewYork"}
print(dict_one)
print(type(dict_one))

Output —

{'Name': 'Steve', 'Location': 'NewYork'}
<class 'dict'>

Implementation —

#Set Data type

set_one = set({"Hello","world","Hello"})
print(set_one)
print(type(set_one))

Output —

{'world', 'Hello'}
<class 'set'>

Implementation —

#Frozen Set

f_one = frozenset({"Hello","World","Hello"})
print(f_one)
print(type(f_one))

Output —

frozenset({'Hello', 'World'})
<class 'frozenset'>

Implementation —

#Boolean Data Type

b = True
print(b)
print(type(b))

Output —

True
<class 'bool'>

Implementation —

#Byte Data Type

byte_one = b"World"
print(type(byte_one))
print(byte_one)

Output —

<class 'bytes'>
b'World'

Python Strings

Strings are arrays of bytes representing unicode characters.

·       Strings in python are surrounded by either single quotation marks, or double quotation marks.

‘today’ is the same as “today”.

Example :

var1 = ‘Hello’

var2 = “Complete Python Course”

·       You can assign a multiline string to a variable by using three quotes.

Implementation —

#String
str1 = "Welcome to complete Python Course"
str2 = 'Welcome to the complete Python Course'
str3 = """This is a
       multiline
       String"""

Output —

Welcome to complete Python Course
Welcome to the complete Python Course
This is a
       multiline
       String

Indexing and Slicing with Strings —

·       In python, Indexing is used to access individual characters of a string

·       Square brackets are used to access the character of the string using Index

·       Index starts with 0

·       -1 refers to the last character, -2 refers to the second last character and so on

Example:

var[3]

var[-2]

·       In python, Slicing is used to access a range of characters in the string

·       Slicing operator colon (:) is used

Example:

var[1:4]

var[:4]

Implementation —

# Indexing : String starts with 0th Index

s= "Captain America"
print(s[4])

Output —

a

Implementation —

#Slicing : slice(start, stop, step), it returns a sliced object containing elements in the given range

s= "Captain America"
print(s[1:5:2])

Output —

at

Implementation —

#Reverse

print(s[::-1])

Output —

aciremA niatpaC

String Methods

·       istitle() : Checks for Titlecased String

·       isupper() : returns if all characters are uppercase characters

·       join() : Returns a Concatenated String

·       ljust() : returns left-justified string of given width

·       lower() : returns lowercased string

·       lstrip() : Removes Leading Characters

·       maketrans() : returns a translation table

·       replace() : Replaces Substring Inside

·       rfind() : Returns the Highest Index of Substring

·       rjust() : returns right-justified string of given width

·       rstrip() : Removes Trailing Characters

·       split() : Splits String from Left

·       splitlines() : Splits String at Line Boundaries

·       startswith() : Checks if String Starts with the Specified String

·       strip() : Removes Both Leading and Trailing Characters

·       swapcase() : swap uppercase characters to lowercase; vice versa

·       title() : Returns a Title Cased String

·       translate() : returns mapped charactered string

·       upper() : returns uppercased string

·       zfill() : Returns a Copy of The String Padded With Zeros

·       capitalize() : Converts first character to Capital Letter

·       casefold() : converts to case folded strings

·       center(): Pads string with specified character

·       count() : returns occurrences of substring in string

·       encode() : returns encoded string of given string

·       endswith(): Checks if String Ends with the Specified Suffix

·       expandtabs() : Replaces Tab character With Spaces

·       find(): Returns the index of first occurrence of substring

·       format(): formats string into nicer output

·       format_map() : Formats the String Using Dictionary

·       index(): Returns Index of Substring

·       isalnum(): Checks Alphanumeric Character

·       isalpha() : Checks if All Characters are Alphabets

·       isdecimal() : Checks Decimal Characters

·       isdigit() : Checks Digit Characters

·       isidentifier() : Checks for Valid Identifier

·       islower() : Checks if all Alphabets in a String are Lowercase

·       isnumeric() : Checks Numeric Characters

·       isprintable() : Checks Printable Character

·       isspace() : Checks Whitespace Characters

Implementation —

#capitalize() method : Returns a copy of the string with its first #character capitalized and the rest lowercased

a = "complete python course"
print(a.capitalize())

Output —

Complete python course

Implementation —

#centre(width[, fillchar])   : Returns the string centered in a #string of length widtha = "Python"

b = a.center(10, "*")
print(b)

Output —

**Python**

Implementation —

# casefold() method : Returns a casefolded copy of the string. #Casefolded strings may be used for caseless matching

a = "PYTHON"
print(a.casefold())

Output —

python

Implementation —

# count(sub[, start[, end]]) : Returns the number of non-overlapping #occurrences of substring (sub) in the range [start, end]

a = "Welcome to complete Python Course"print(a.count("c"))
print(a.count("o"))
print(a.count("Python"))

Output —

2
5
1

Implementation —

# endswith(suffix[, start[, end]]) : Returns True if the string ends #with the specified suffix, otherwise it returns False

a = "Watermelon"
print(a.endswith("s"))
print(a.endswith("melon"))

Output —

False
True

Implementation —

# find(sub[, start[, end]]) : Returns the lowest index in the string # where substring sub is found within the slice s[start:end]

a = "Exercise"
print(a.find("r"))
print(a.find("e"))

Output —

3
2

Implementation —

# index(sub[, start[, end]]) : Similar to find function, except that # it raises a ValueError when the substring is not found

a = "Continent"
print(a.index("i"))
print(a.index("C"))
print(a.index("nent"))

Output —

4
0
5

Implementation —

# isalnum() : Returns True if all characters in the string are #alphanumeric, else returns False

c = "456"
d = "$*%!!**"
print(c.isalnum())
print(d.isalnum())

Output —

True
False

Implementation —

# isalpha() : Returns True if all characters in the string are #alphabetic, else returns False

c = "456"
d = "Python"
print(c.isalpha())
print(d.isalpha())

Output —

False
True

Implementation —

# isdecimal() : Returns True if all characters in the string are #decimal characters, else returns False

c = u"\u00B10"
x = "10"
print(c.isdecimal())
print(x.isdecimal())

Output —

False
True

Implementation —

# isdigit() : Returns True if all characters in the string are #digits, else returns False

c = "4567"
d = "1.65"
print(c.isdigit())
print(d.isdigit())

Output —

True
False

Implementation —

# join(iterable) : Returns a string which is the concatenation of #the strings in iterable.
# A TypeError will be raised if there are any non-string values in #iterable

a = ","
print(a.join("CD"))

Output —

C,D

Implementation —

# partition(sep) : Splits the string at the first occurrence of sep, #and returns a 3-tuple containing the part before the separator, the #separator itself, and the part after the separator

a = "Complete.Python-course"print(a.partition("-"))
print(a.partition("."))

Output —

('Complete.Python', '-', 'course')
('Complete', '.', 'Python-course')

Implementation —

# split(sep=None, maxsplit=-1) : Returns a list of the words in the #string,using sep as the delimiter strip.If maxsplit is given,at #most maxsplit splits are done.If maxsplit is not specified or -1, #then there is no limit on the number of splits.

a = "Welcome,,Friends,"
print(a.split(","))

Output —

['Welcome', '', 'Friends', '']

Implementation —

# strip([chars]) : Returns a copy of the string with leading and #trailing characters removed. The chars argument is a string #specifying the set of characters to be removed

a = "***Python***"
print(a.strip("*"))

Output —

Python

Implementation —

# swapcase() : Returns a copy of the string with uppercase #characters converted to lowercase and vice versa

a = "Hi Homies"
print(a.swapcase())

Output —

hI hOMIES

Implementation —

# zfill(width) : Returns a copy of the string left filled with ASCII #0 digits to make a string of length width

a = "-124"
print(a.zfill(6))

Output —

-00124

Implementation —

# lstrip([chars]) : Return a copy of the string with leading #characters removed.The chars argument is a string specifying the #set of characters to be removed.

a = "*****Python-----"

print(a.lstrip("*"))

Output —

Python-----

Implementation —

# rindex(sub[, start[, end]]) : Just like rfind() but raises #ValueError when the substring sub is not found

a = "Hi World"print(a.rindex("d"))
print(a.rindex("W"))

Output —

7
3

Python F Strings

  • Python F-String are used to embed python expressions inside string literals for formatting, using minimal syntax.
  • It’s an expression that’s evaluated at the run time.
  • They have the f prefix and use {} brackets to evaluate values.
  • f-strings are faster than %-formatting and str.format()

Syntax —

f “string_variable”

  • In order to format and output an expression in the formatted way, you should use curly braces {}

Implementation —

def max_no(x,y):
    return x if x>y else y
f_no= 12
s_no =25
print(f'Max of {f_no} and {s_no} is {max(f_no,s_no)}')

Output —

Max of 12 and 25 is 25

Implementation —

from decimal import Decimal
width = 4
round_point = 2
value = Decimal('12.39065')
print(f'result:{value:{width}.{round_point}}')

Output —

result:  12

Operators in Python

·       In python, operators are used to perform operations on variables and values

  • Arithmetic operators : +, — , *, /, //, %, **
  • Logical operators : and, or, not
  • Identity operators : is, is not
  • Membership operators : in , not in
  • Bitwise operators : &, |, ^,~, << , >>
  • Assignment operators : =, +=, -=, *=,/= , %=, //=, **=, &=, |=, ^=, >>=, <<=
  • Comparison operators : ==, !=, > , <, >=, <=
  • Ternary operators are operators that evaluate things based on a condition being true or false

Syntax : [true] if [expression] else [false]

Operator overloading can be implemented in Python




Example —


a & b

a >> 2

a is not b

‘b’ in list1

Implementation —

#Arithmatic Operators

x=10
y=4#Addition
print("Addition:",x+y)#Subtraction
print("Subtraction:",x-y)#Multiply
print("Multiply: ",x*y)#Division
print("Division:",x/y)#Modulus
print("Modulus:",x%y)#Floor Division
print("Floor Division:",x//y)#Exponent
print("Exponent:",x**y)

Output —

Addition: 14
Subtraction: 6
Multiply:  40
Division: 2.5
Modulus: 2
Floor Division: 2
Exponent: 10000

Implementation —

#Comparison Operator  : Result is either True or False

x=5
y=3#Greater than
print("Greater than:",x>y)#Less than
print("Greater than:",x<y)#Greater than equal to
print("Greater than equal to:",x>=y)#less than equal to
print("Less than:",x<=y)#Not equal to
print("Not equal to:",x!=y)#Equal to
print("Equal to:",x==y)

Output —

Greater than: True
Greater than: False
Greater than equal to: True
Less than: False
Not equal to: True
Equal to: False

Implementation —

#Logical Operators : and, or, not [Result is either True or False]

x= True
y= False#And
print("And result:",(x and y))#Or
print("Or result:",(x or y))#Not
print("Not result:",(not y))

Output —

And result: False
Or result: True
Not result: True

Implementation —

# Bitwise operators

x = 1001
y = 1010#And
print("And result:",(x & y))#Or
print("Or result:",(x | y))#Not
print("Not result:",(~y))#Xor
print("XOR result:",(x^y))#Bitwise right shift
print("Bitwise right shift result:",(x>>2))#Bitwise left shift
print("Bitwise left shift result:",(x<<2))

Output —

And result: 992
Or result: 1019
Not result: -1011
XOR result: 27
Bitwise right shift result: 250
Bitwise left shift result: 4004

Implementation —

# Assignment operators : used in Python to assign values to variables

x=5
x+=5
x-=2
x*=2
x**=2

Implementation —

# Identity Operator : is and is not are the identity operators in Python

x=5
y=5
z='a'
print("Is operator result:", (x is y))
print("Not is operator result:", (y is not z))

Output —

Is operator result: True
Not is operator result: True

Implementation —

#Membership operator : in operator

x = 'Python Course'
print('y' in x)
print('a' in x)

Output —

True
False

Chaining Comparison Operators with Logical Operator:

  •  In python, in order to check more than two conditions, we implement chaining where two or more operators are chained together as shown in the example below

if x < y < z :

{…..}

  •  In accordance with associativity and precedence in Python, all comparison operations have the same priority. Resultant values of Comparisons yield boolean values such as either True or False
  • When chaining the comparison operators, the sequence can be arbitrary.

Example —

x > y <= c is equivalent to x > y and y <= c

Implementation —

#Chaining Comparison operators with Logical operators

a, b, c, d, e, f, g = 10, 15, 2, 1, 45, 25, 19
e1 = a <= b < c > d < e is not f is g
e2 = a is d < f is cprint(e1)
print(e2)

Output —

False
False

Python Lists

  • One of the most versatile data type in Python, Lists are used to store multiple items ( homogeneous or non-homogeneous) in a single variable.
  • Place the items inside the square brackets[]
  • Items can be of any data type
  • Lists are defined as objects with the data type ‘list’
  • Items are ordered, changeable, and allow duplicate values
  • list() constructor can be used when creating a new list
  • To access values in lists, use the square brackets for slicing along with the index to obtain item value available at a particular index
  • Items inside list are indexed, the first item has index [0], the second item has index [1] etc

Example —

var=[1, 2 , ‘car’, ‘sunday’ , 3.14]

empty_list = []

items = list((“apple”, “banana”, “grapes”))

Implementation —

#Create a List\

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
print(list_one)

Output —

['sunday', 'monday', 'tuesday', 'wednesday', 'thursday']

Implementation —

#List Length

print(len(list_one))

Output —

5

Implementation —

# List with different data types

list_two = ['abc',67,True,3.14,"female"]
print(list_two)

Output —

['abc', 67, True, 3.14, 'female']

Implementation —

#type() with List
print(type(list_two))

Output —

<class 'list'>

Implementation —

#list() constructor to make a List

list_cons = list(("hello","World","Beautiful","Day"))
print(list_cons)

Output —

['hello', 'World', 'Beautiful', 'Day']

Implementation —

# nested list

list_nest= ["hello",[8,4,6],['World']]
print(list_nest)

Output —

['hello', [8, 4, 6], ['World']]

Implementation —

#slice lists in Python : Use the slicing operator :(colon)


list_one = ["sunday","monday","tuesday","wednesday","thursday"]
print(list_one[1:4])

Output —

['monday', 'tuesday', 'wednesday']

Implementation —

#Add/Change List Elements : use the assignment operator = to change #an item

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
list_one[3] = 'friday'
print(list_one)

Output —

['sunday', 'monday', 'tuesday', 'friday', 'thursday']

Implementation —

# Appending and Extending lists in Python : Use the append() or #extend() method

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
list_one.append('friday')
print(list_one)#extendlist_one.extend(['saturday'])
print(list_one)

Output —

['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday']
['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday']

Implementation —

# Concatenating and repeat lists : use + operator to concate two #lists and use * operator to repeat lists

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
print(list_one + [0,1,2,3,4])#repeat operation
print(['a','b']*2)

Output —

['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 0, 1, 2, 3, 4]
['a', 'b', 'a', 'b']

Implementation —

# Delete/Remove List Elements : delete one or more items or entire list using the keyword deldel list_one[2]
print(list_one)#remove method : remove the given item or pop() method to remove an item at the given index location


list_one = ["sunday","monday","tuesday","wednesday","thursday"]

list_one.remove("tuesday")

print(list_one)#pop methodlist_one = ["sunday","monday","tuesday","wednesday","thursday"]

list_one.pop(2)

print("Pop result:", list_one)

Output —

['sunday', 'monday', 'thursday']
['sunday', 'monday', 'wednesday', 'thursday']
Pop result: ['sunday', 'monday', 'wednesday', 'thursday']

Implementation —

# index() method : Returns the index of the first matched item

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
print(list_one.index("tuesday"))

Output —

2

Implementation —

# sort() method: Sort items in a list in ascending order

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
list_one.sort()
print(list_one)

Output —

['monday', 'sunday', 'thursday', 'tuesday', 'wednesday']

Implementation —

# reverse() : Reverse the order of items in the list

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
list_one.reverse()
print(list_one)

Output —

['thursday', 'wednesday', 'tuesday', 'monday', 'sunday']

Implementation —

# copy(): Returns a shallow copy of the list

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
list_two = list_one.copy()
print(list_two)

Output —

['sunday', 'monday', 'tuesday', 'wednesday', 'thursday']

Implementation —

#Membership : check if an item exists in a list or not, using the keyword in

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
print('tuesday' in list_one)

Output —

True

Implementation —

# insert() method : insert item at a desired location

list_one = ["sunday","monday","tuesday","wednesday","thursday"]
list_one.insert(2,'friday')
print(list_one)

Output —

['sunday', 'monday', 'friday', 'tuesday', 'wednesday', 'thursday']

List Comprehensions

  • In python, list comprehensions are used to create a new list based on the values of an existing list in the most elegant and shortest way.
  • List comprehension consists of an expression followed by for statement inside square [] brackets.

Example :

new_list = [x for x in list1 if “a” in x]

Implementation —

sqr = [2**x for x in range(20)]
print(sqr)

Output —

[1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768, 65536, 131072, 262144, 524288]

Python Dictionaries 


  • In python, dictionary is an unordered collection of data values in which data values are stored in key:value pairs
  • Created by placing sequence of elements within curly {} braces, separated by ‘ , ‘
  • Values can be of any datatype and can be duplicated, whereas keys are immutable and can’t be repeated
  • Can be created by the built-in function dict()
  • Dictionaries are defined as objects with the data type ‘dict
  • dict() constructor can be used when creating a new dict
  • To access values in dict, use the keys
  • Key Value format makes dictionary one of the most optimized and efficient data type in Python

Example —

var={ ‘first_day’: ‘sunday’ , ‘second_day’: ‘monday’, ‘third_day’: ‘tuesday’}

empty_dict = {}

class dict(**kwarg)

Implementation —

#Create a Dictionary#empty dictionary
dict_emp = {}#dict with items
dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(dict_one)

Output —

{0: 'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}

Implementation —

#Accessing Elements from Dictionary : Using keys or get() method

dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(dict_one[1])#get() method
print(dict_one.get(2))

Output —

monday
tuesday

Implementation —

# Length of Dictionary
dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(len(dict_one))

Output —

5

Implementation —

#Changing and Adding Dictionary elements: add new items or change the value of existing items using an = operator

dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}#change element
dict_one[2] = 'friday'
print("After changing the element", dict_one)#Add element
dict_one[5] = 'saturday'
print("After adding the element :", dict_one)

Output —

After changing the element {0: 'sunday', 1: 'monday', 2: 'friday', 3: 'wednesday', 4: 'thursday'}
After adding the element : {0: 'sunday', 1: 'monday', 2: 'friday', 3: 'wednesday', 4: 'thursday', 5: 'saturday'}

Implementation —

#Removing elements from Dictionary : Use the pop() or popitem() #method

dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(dict_one.pop(2))#popitem : remove an arbitrary item and return (key,value)print(dict_one.popitem())

Output —

tuesday
(4, 'thursday')

Implementation —

# remove all items : using clear method

dict_one.clear()
print(dict_one)

Output —

{}

Implementation —

#fromkeys(seq[, t]): Returns a new dictionary with keys from seq and value equal to t

subjects = {}.fromkeys(['Computer Science','Space Science','Math','English'])
print(subjects)

Output —

{'Computer Science': None, 'Space Science': None, 'Math': None, 'English': None}

Implementation —

#items() method : displays a list of dictionary's (key, value) tuple pairs

dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(dict_one.items())

Output —

dict_items([(0, 'sunday'), (1, 'monday'), (2, 'tuesday'), (3, 'wednesday'), (4, 'thursday')])

Implementation —

#keys() method : displays a list of all the keys in the dictionary

dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(dict_one.keys())

Output —

dict_keys([0, 1, 2, 3, 4])

Implementation —

#values() method : displays a list of all the values in the dictionary
dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(dict_one.values())

Output —

dict_values(['sunday', 'monday', 'tuesday', 'wednesday', 'thursday'])

Implementation —

#setdefault() method : returns the value of a key. If not there, it inserts key with a value to the dictionary
dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
element = dict_one.setdefault(3)
print(element)#If key not present
element = dict_one.setdefault(6)
print("If key is not present:", dict_one.items())

Output —

wednesday
If key is not present: dict_items([(0, 'sunday'), (1, 'monday'), (2, 'tuesday'), (3, 'wednesday'), (4, 'thursday'), (6, None)])

Implementation —

#Nested Dictionaries
people = {"subject": {0:"Maths",1:"English",3:"Science"},
          "marks": {0:42,1:36,2: 78},
          "Age": {0:12,1:34,2:19}
         }
#print(people["marks"][0])
print(people["Age"][0])

Output —

42

Implementation —

#sorted(): Return a new sorted list of keys in the dictionary
dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(sorted(dict_one))

Output —

[0, 1, 2, 3, 4]

Implementation —

#Iterate through dictionay

dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
for i in dict_one.items():
    print(i)

Output —

(0, 'sunday')
(1, 'monday')
(2, 'tuesday')
(3, 'wednesday')
(4, 'thursday')

Implementation —

# Dictionary Comprehension

cubes = {x: x*x*x for x in range(10)}
print(cubes)

Output —

{0: 0, 1: 1, 2: 8, 3: 27, 4: 64, 5: 125, 6: 216, 7: 343, 8: 512, 9: 729}

Implementation —

# update() method : updates the dictionary with the elements from
# another dictionary object or from any other key/value pairs


dict1 ={0:"zero",4:"four",5:"five"}
dict2={2:"two"}
# updates the value of key 2
dict1.update(dict2)
print(dict1)

Output —

{0: 'zero', 4: 'four', 5: 'five', 2: 'two'}

Implementation —

# Membership Test : check if a key is in a dictionary or not using #the keyword in

dict_one = {0:'sunday', 1: 'monday', 2: 'tuesday', 3: 'wednesday', 4: 'thursday'}
print(0 in dict_one.keys())

Output —

True

Python Tuples

  • In python, a tuple is a collection of objects which is ordered and immutable
  • Created by placing sequence of elements within round () braces, separated by ‘ , ‘
  • Values can be of any datatype
  • Concatenation of tuples can be done by the use of ‘+’ operator
  • Tuples are just like lists except that the tuples are immutable i.e cannot be changed

Example —

var= (4, ‘Hello’, 5, ‘World’)

empty_tuple = ()

Implementation —

# Tuple with items

tup= (10,"Hello",3.14,"a")
print(tup)
print(type(tup))

Output —

(10, 'Hello', 3.14, 'a')
<class 'tuple'>

Implementation —

# Negative Indexing : index of -1 refers to the last item, -2 to the #second last item and so on

tup = (10,"Hello",3.14,"a")
print(tup[-2])#Reverse the tuple
print(tup[::-1])

Output —

3.14
('a', 3.14, 'Hello', 10)

Implementation —

#concatenation and repeat in Tuples#concatenation using + operator

tup = (10,"Hello",3.14,"a")
print(tup + (50,60))#repeat using * operator
print(tup * 2)

Output —

(10, 'Hello', 3.14, 'a', 50, 60)
(10, 'Hello', 3.14, 'a', 10, 'Hello', 3.14, 'a')

Implementation —

#membership : check if an item exists in a tuple or not, using the keyword in

tup = (10,"Hello",3.14,"a")
print(10 in tup)
print("World" in tup)

Output —

True
False

Implementation —

#Iterate through Tuple : use for loop to iterate through each item #in a tuple

tup = (10,"Hello",3.14,"a")
for i in tup:
    print(i)

Output —

10
Hello
3.14
a

Implementation —

#Nested Tuple

nest_tup = ((10,"Hello",3.14,"a"), (70,(8,"Mike")))
print(nest_tup)a,b = nest_tup
print(a)
print(b)

Output —

((10, 'Hello', 3.14, 'a'), (70, (8, 'Mike')))
(10, 'Hello', 3.14, 'a')
(70, (8, 'Mike'))

Implementation —

#Enumerate : use enumerate function

tup = (10,"Hello",3.14,"a")
for i in enumerate(tup):
    print(i)

Output —

(0, 10)
(1, 'Hello')
(2, 3.14)
(3, 'a')

Python Sets

  • In python, a set is a collection of objects which is both unindexed and unordered
  • Sets make sure that there are no duplicate elements in the items sequence
  • Created by using the built-in set() function with an iterable object by placing the items inside curly {} braces, separated by ‘,’
  • Items can be added to the set by using built-in add() function
  • Items can be accessed by looping through the set using loops or using ‘in’ keyword
  • Items can be removed from the set by using built-in remove()

Example —

var= set([“Hello”, “People”, “Hello”])

Implementation —

#Create Set
set_one = {10, 20, 30, 40}
print(set_one)#Create set from list using set()
set_two = set([10, 20, 30, 40, 30, 20])
print(set_two)

Output —

{40, 10, 20, 30}
{40, 10, 20, 30}

Implementation —

# Removing elements : Use the methods discard(), pop() and remove()
#set_one is {100, 70, 40, 10, 80, 20, 60, 30}
#discard() method

set_one.discard(100)
print("After discard:",set_one)#remove() method
set_one.remove(40)
print("After removing element :", set_one)#pop() method
set_one.pop()
print("After removing element :", set_one)

Output —

After discard: {70, 40, 10, 80, 20, 60, 30}
After removing element : {70, 10, 80, 20, 60, 30}
After removing element : {10, 80, 20, 60, 30}

Implementation —

#Set operations
X = {10, 20, 30, 40, 50}
Y = {40, 50, 60, 70, 80}
Z = {20, 30, 100, 50, 10}#Union : Union of X, Y, Z is a set of all elements from all three #sets using | operator or union() method
print("Set Union:", X|Y|Z)#Intersection :Intersection of X, Y, Z is a set of all elements from #all three sets using & operator or intersection()
print("Set Intersection:", X&Y&Z)#Difference : Difference of X, Y is a set of all elements from both #sets using - operator or difference()
print("Set Difference:", X-Y)# Symmetric Difference : Symmetric Difference of X, Y, Z is a set of #all elements from all three sets using ^ operator or #symmetric_difference()           
print("Set Symmetric Difference:", X^Y^Z)

Output —

Set Union: {100, 70, 40, 10, 80, 50, 20, 60, 30}
Set Intersection: {50}
Set Difference: {10, 20, 30}
Set Symmetric Difference: {80, 50, 100, 70, 60}

Implementation —

#enumerate : Returns an enumerate object which contains the index #and value for all the items of the set as a pairset_one = {10, 20, 30, 40, 50, 30}
for i in enumerate(set_one):
    print(i)

Output —

(0, 40)
(1, 10)
(2, 50)
(3, 20)
(4, 30)

Implementation —

#Frozenset : set which has the characteristics of a set, but its elements cannot be changed once assigned

X = frozenset([10, 20, 30, 40, 50])
Y = frozenset([40, 50, 60, 70, 80])print(X.union(Y))

Output —

frozenset({70, 40, 10, 80, 50, 20, 60, 30})

Loops in Python

If, Elif and Else Statements —

  • In python, If, Elif and Else statements are used to facilitate decision making i.e when we want to execute a code only if a certain condition is satisfied.
  • In the example below, the program evaluates the test expression and will execute statement(s) only if the test expression is True. If the test expression1 is False, then it checks elif test expression 2 and if that’s also False, then at last it goes to else and executed else statement.

if test_expression1:

statement(s)

elif test_expression2:

statements(s)

else :

statement

  • Python interprets non-zero values as True. None and 0 are interpreted as False.
  • The if block can have only one else block but there can be multiple elif blocks.

While loops —

  • In python, while loop is used to traverse/iterate over a block of code as long as the test condition is true
  • In the example below, test_expression is checked first. The body of the loop is entered only if the test_expression evaluates to True. The loop continues till the test condition becomes False.

while test_expression:

Do this

Example :

while i <= 10:

sum = sum — i

i = i+1

For Loops and Range function —

·       In python, for loop is used to traverse/iterate over a sequence (list, tuple, string etc)

·       In the example below, i is the variable that takes the value of the item inside the sequence on each iteration. Loop continues until we reach the last item in the sequence

for i in sequence:

Do this

Range ( range()) is used to generate sequence of numbers where the syntax of range is

range(start, stop, step_size)

Example :

for i in range(len(list1)):

print(“The element is “, list1[i])

Implementation —

price = 200if price > 120:
    print("Price is greater than 120")
elif price == 120:
    print("Price is 120")
elif price < 120:
    print("Price is less than 120")
else:
    print("Exit")

Output —

Price is greater than 120

Implementation —

# If, Elif and Else one liner
x = 200
 
var = {x < 190: "Condition one satisfied",
       x != 200: "Condition two satisfied"}.get(True, "Condition third satisfied")
 
print(var)

Output —

Condition third satisfied

Implementation —

#while with else statement
i = 1
while i < 6:
  print(i)
  i += 1
else:
  print("i is no longer less than 6")

Output —

1
2
3
4
5
i is no longer less than 6

Implementation —

# for loop with range function

days =['sunday','monday','tuesday']
for i in range(len(days)):
    print("Today is", days[i])

Output —

Today is sunday
Today is monday
Today is tuesday

Break and Continue Statement

  • In python, we can use break statement when we want to terminate the current loop without checking test condition
  • Once terminated using the break statement, the control of the program goes to the statement immediately after the body of the loop

Example :

for value in list1:

if value == “t”:

break

print(value)

  • In python, we can use continue statement when we want to skip the rest of the code for the current loop iteration

Example :

for value in list1:

if value == “t”:

continue

print(value)

Implementation —

#break statement
count = 0
while True:
    print(count)
    count += 1
    if count >= 10:
        breakprint('exit')

Output —

0
1
2
3
4
5
6
7
8
9
exit

Implementation —

#Continue statement
for x in range(15):
    if x % 2 == 0:
        continue
    print(x)

Output —

1
3
5
7
9
11
13

Input Output in Python

·       In python, there are two inbuilt functions to read the input from the user

raw_input ( ) function : reads one line from user input and returns it as a string

input ( ) function : Similar to raw_input, except it evaluates the user expression

·       For multiple user inputs, we can use —

split() method

List comprehension

·       In python, output is using the print() function

·       String literals in print() statement are used to format the output

\n : Add blank new line

“” : To print an empty line.

·       end keyword is used to print specific content at the end of the execution of the print() function

Example —

num= input(“Enter the number: “)

str = raw_input(“Enter your input: “)

print(“Python” , end = ‘**’)

Implementation —

# inputnum = int(input('Enter a number: '))

Output —

Enter a number: 50

Implementation —

num = 5
print('The value of num is', num)
print("The value is %d" %num)

Output —

The value of num is 5
The value is 5

Python Object Oriented Programming

  • Python is a multi-paradigm programming language and supports Object Oriented programming. In Python everything is a object. An object has two characteristics : Attributes and Behavior
  • Principles of object-oriented programming system are —

Class

Object

Method

Inheritance

Polymorphism

Encapsulation

  • Class and constructor — It’s a blueprint for the object. In python we use the class keyword to define class. Class constructor is used to assign the values to the data members of the class when an object of the class is created.
  • Object — It’s an instantiation of a class.
  • Method — It’s a function that is associated with an object
  • Inheritance — Specifies that the child object acquires all the properties and behaviors of the parent object.
  • Polymorphism — Refers to functions having the same names but carrying different functionalities.
  • Encapsulation — To prevents data from direct modification, we can restrict access to methods and variables in python

Attributes and Class in Python

·       In Python, a class is blueprint of the object

·       To define a class, we use the keyword “class” following the class name and semicolon —

class class_name:

Body of the class

·       Object — It’s an instantiation of a class. The object instance contains real data or value

To create an instance :

obj1 = class_name()

·       Class constructor — to assign the values to the data members of the class when an object of the class is created, we use constructor. The __init__() method is called constructor method

class class_name:

def __init__(self, parameters):

self.param1 = parameters

  • Instance attributes refer to the attributes inside the constructor method. Class attributes refer to the attributes outside the constructor method
  • ·Method — It’s a function that is associated with an object, used to describe the behavior of the objects

def method_name(self)

Implementation —

#Class implementation
class cat:def __init__(self, cat_name, cat_breed):
        self.name = cat_name
        self.age = cat_breed

Implementation —

#Class attribute and Instance Attributeclass emp:
    x = 10      #class attribute
    def __init__(self):
        self.name = 'Steve'
        self.salary = 10000
 
    def display(self):
        print(self.name)
        print(self.salary)
 
obj_emp = emp()
print("Dictionary conversion:", vars(obj_emp))

Output —

Dictionary conversion: {'name': 'Steve', 'salary': 10000}

Functions in Python

In python, functions are a convenient way to divide your code into useful blocks, allowing us to order our code, make it more readable, reuse it, define interfaces and save a lot of time

  • A function can be called multiple times to provide modularity and reusability to the python program
  • We can easily track a large python program easily when it is divided into multiple functions
  • There are mainly two types of functions — 
  • User-define functions — Defined by the user to perform the specific taskBuilt-in functions — Functions which are pre-defined
  • You can define the function using the def keyword
  • Arguments is the information that’s passed into the function
  • The return statement is used to return the value. A function can have only one return
  • Once created, we can call the function using the function name followed by the parentheses

Example :

def my_function(parameters):

print(“My first Function”)

return expression

#calling the function

my_function()

Private Variables in Python

In python, a variable is a named location used to store or hold the value/data in the memory.

  • When we create a variable inside a function, it is local by default
  • We create Private Variables by using underscore _ before a named prefix
  • This is quite helpful for letting subclasses override methods without breaking intraclass method calls

There are three ways private variables can be implemented :

_Single Leading Underscores

__Double Leading Underscores

__Double leading and Double trailing underscores__

·       __name__ is a special built-in variable which points to the name of the current module

Example :

_program

__var

__len__

Implementation —

# Private Variable
#Single underscore (_)
class test:
    def __init__(self,num):
        self._num= num#_privatemethod private method
    def _numfunc(self):
        print("Hello")obj=test(156)
#_ attributes can be accessed as normal variables
obj._numfunc()

Implementation —

# Private Variable
#Double Underscore (__)class test:
    def __init__(self,num):
        self.__num= num
    def Print(self):
        print("__num = {}".format(self.__num))obj=test(156)

Implementation —

# Private Variable
#Trailing underscore(n_)class Test:
    def __init__(self,c):
        #To avoid clash with python keyword
        self.num_= num

Global and Non Local Variables in Python

When we create a variable inside a function, it is local by default. When we define a variable outside of a function, it is global by default

  • Nonlocal variables are used in nested functions whose local scope is not defined
  • Global variables are those variables which are defined and declared outside a function and we can use them inside the function or we can use global keyword to make a variable global inside a function

Example :

global variable_name

Implementation —

#Local Variabledef test():
    l = "local_variable"
    return lvar=test()
print(var)

Output —

local_variable

Implementation —

#Global Variablevar = 10def test():
    var = 20
    print("local variable x:", var)val=test()
print("global variable x:", var)

Output —

local variable x: 20
global variable x: 10

Implementation —

#Non Local Variabledef test():
    var = "local_variable"def test_one():
        nonlocal var
        var = "non_local_variable"
        print("Non Local value:", var)
    test_one()
    print("Outer value:", var)
test()

First Class functions in Python

In python, a function in Python is First Class Function, if it supports all of the properties of a First Class object such as —

It is an instance of an Object type

Pass First Class Function as argument of some other functions

Return Functions from other function

Store Functions in lists, sets or some other data structures

Functions can be stored as variable

  • In Python, a function can be assigned as variable which is used without function parentheses
  • Functions are objects you can pass them as arguments to other functions
  •  First-class functions allow you to pass around behavior and abstract
  • Closure functions — Functions are be nested and they can carry forward parent function’s state with them

Example :

def func1(func):

var = func(‘Hello World’)

print(var)

Implementation —

#Implementation 2
def outer(a):   # Outer functiondef inner(b):   # Inner function
        return b+10
    return inner(a)a = 10
var = outer(a)
print(var)

Output —

20

__import__() function

In python, the inbuilt __import__() function helps to import modules in runtime

Syntax —

__import__(name, globals, locals, fromlist, level)

  • name : Name of the module to import.
  • globals : Dictionary of global names used to determine how to interpret the name in a package context.
  • locals : Dictionary of local names names used to determine how to interpret the name in a package context.
  • fromlist : The fromlist gives the names of objects or submodules that should be imported from the module given by name.
  • level : level specifies whether to use absolute or relative imports.
  • To import a module by name, use importlib.import_module()

Example :

_var = __import__(‘spam.ham’, globals(), locals(), [], -1)

Implementation —

#implementation
#fabs() method is defined in the math module which returns the #absolute value of a number
math_score = __import__('math', globals(), locals(), [], 0)
print(math_score.fabs(-17.4))

Output —

17.4

Tuple Unpacking with Python Functions

In python, tuples are immutable data types. Python offers a very powerful tuple assignment tool that maps right hand side arguments into left hand side arguments i.e mapping is known as unpacking of a tuple of values into a normal variable.

  • During the unpacking of tuple, the total number of variables on the left-hand side should be equivalent to the total number of values in given tuple
  • It uses a special syntax to pass optional arguments (*args) for tuple unpacking

Example :

days = (“sunday”, “monday”, “tuesday”,”wednesday”,”thursday”)

(day1, day2, *day) = days

Implementation —

def result(a, b):
    return a + b
# function with normal variables
print (result(100, 200))
 
# A tuple is created
c = (100, 300)
 
# Tuple is passed
# function unpacked them
 
print (result(*c))

Output —

300
400

Static Variables and Methods in Python

In Python, Static variables are the variables that belong to the class and not to objects.

·       Static variables are shared amongst objects of the class

·       Python allows providing same variable name for a class/static variable and an instance variable

Static Method -

·       In Python, Static methods are the methods which are bound to the class rather than an object of the class

·       Static Methods are called using the class name and not the objects of the class

·       Static methods are bound to the class

·       There are two ways of defining a static method:

@staticmethod

staticmethod()

Example :

class class_name:

@staticmethod

def function_name(parameters):

print(var)

Implementation —

class test:
    static_variable = 25 # Access through classprint(test.static_variable) # prints 5# Access through an instance
ins = test()
print(ins.static_variable) # still 5# Change within an instance
ins.static_variable = 14
print(ins.static_variable)
print(test.static_variable)

Output —

25
25
14
25

Implementation —

# Static Method : Use @staticmethod
class sample_shape:
   
    @staticmethod
    def msgg(msg):
        print(msg)
        print("Triangles")
       
sample_shape.msgg("Welcome to sample shape class")

Output —

Welcome to sample shape class
Triangles

Lambda Functions in Python

In python, Lambda is used to create small anonymous functions using “lambda” keyword and can be used wherever function objects are needed.It can any number of arguments but only one expression

Syntax :

lambda argument(s): expression

·       It can be used inside another function

·       In python normal functions are defined using the def keyword, anonymous functions are defined using the lambda keyword

·       Whenever we require a nameless function for a short period of time, we use lambda functions

Example :

var = lambda x: x * 5

Implementation —

#A lambda function that adds 10 to the number passed in as an #argument, and print the result
x = lambda a, b, c : a * b + c
print(x(5, 6, 8))

Output —

38

Map and Filter Functions in Python

In python, Map allows you to process and transform the items of the iterables or collections without using a for loop.

·       In Python, the map() function applies the given function to each item of a given iterable construct (i.e lists, tuples etc) and returns a map object

Syntax —

map(function, iterable)

·       In python, filter() function returns an iterator when the items are filtered through a function to test if the item is true or not

Syntax —

filter(function, iterable)

where function is the to be run for each item in the iterable

iterable is the iterable to be filtered

Example :

result = map(lambda x: x+x, numbers)

var = filter(function_name, sequence)

Implementation —

#map
numbers = [1,2,3,4,5]
strings = ['s', 't', 'x', 'y', 'z']mapped_list = list(map(lambda x, y: (x, y), strings, numbers))print(mapped_list)

Output —

[('s', 1), ('t', 2), ('x', 3), ('y', 4), ('z', 5)]

Implementation —

#map implementation
days = ['Sunday', 'Monday', 'Tuesday', 'Wednesday']mod_days = list(map(str.swapcase, days))print(mod_days)

Output —

['sUNDAY', 'mONDAY', 'tUESDAY', 'wEDNESDAY']

Implementation —

#Filter functionmarks = [95, 40, 68, 95, 67, 61, 88, 23, 38, 92]def stud(score):
    return score < 33fail_list = list(filter(stud, marks))
print(fail_list)

Output —

[23]


No comments:

Post a Comment

Spark- Window Function

  Window functions in Spark ================================================ -> Spark Window functions operate on a group of rows like pa...