Unit 3:-Data Structurein Python
⢠3.1 List
a) Defining list , accessing value in list, deleting value in list, updating list
b) Basic list Operations
c) Built in List-functions
2.
Defining list
Creating alist is as simple as putting different comma-separated
values between square brackets.
⢠# List of integers
⢠a = [1, 2, 3, 4, 5]
⢠# List of strings
⢠b = ['apple', 'banana', 'cherry']
⢠# Mixed data types
⢠c = ['PWP', 'MAD', 6, 20]
⢠print(a)
⢠print(b)
3.
accessing value inlist with index no
⢠S=âpythonâ
⢠Print(s[0])----------p
⢠a = [10, 20, 30, 40, 50]
⢠# Access first element
⢠print(a[0])---------10
⢠# Access last element
⢠print(a[-1])-----------50
a = [1,2, 3, 4, 5, 6, 7, 8, 9]
b = a[-2:]
print(b)
c = a[:-3]
print(c)
d = a[-4:-1]
print(d)
e = a[-8:-1:2]
print(e)
# Get the entire list reverse using negative
step
b = a[::-1]
print(b)
my_list = [1, 2, 3, 4, 5]
print(my_list[-1:3:-1]) --> 5
print(my_list[1:3:-1])----- []
6.
deleting value inlist
⢠Lists in Python have various built-in methods to remove items such
as remove, pop, del and clear methods.
remove():-
⢠The remove() method deletes the first occurrence of a specified value in the list.
If multiple items have the same value, only the first match is removed.
⢠Syntax remove(value only)
⢠a = [10, 20, 30, 40, 50]
⢠a.remove(30)
⢠print(a) ---------- [10, 20, 40, 50]
7.
Pop(): The pop()method can be used to remove an element from a list based
on its index and it also returns the removed element.
⢠a = [10, 20, 30, 40, 50]
val = a.pop(1)
print(a)
print("Removed Item:", val)
Output:-
[10, 30, 40, 50]
Removed Item: 20
8.
del():The del statementcan remove elements from a list by
specifying their index or a range of indices.
⢠Example:
⢠a = [10, 20, 30, 40, 50,60,70]
⢠del a[2]
⢠print(a)----------Output:[10, 20, 40, 50]
⢠del a[1:4]
⢠print(a)----------ď [10, 50, 60, 70]
9.
Clear():-If we wantto remove all elements from a list then we can use
the clear() method. and return empty list
a = [10, 20, 30, 40]
a.clear()
print(a)------------------output:-[]
10.
Updating list
⢠Tochange the value of a specific item, refer to the index number
⢠a = ["apple", "banana", "cherry"]
⢠a[1] = " pineapple "
⢠print(a)
#Change a Range of Item Values
b = ["apple", "banana", "cherry", "orange", "kiwi", "mango"]
b[1:3] = [âpineapple", "watermelon"]
print(b)
11.
⢠Python ListOperations
⢠Consider a List l1 = [1, 2, 3, 4] and l2 = [5, 6, 7, 8]
1.Repetition:- The repetition operator enables the list elements to be repeated multiple times.
⢠EX- print(L1*2 )-------------------[1, 2, 3, 4, 1, 2, 3, 4]
2. Concatenation:- It concatenates the list mentioned on either side of the operator.
⢠Ex- print(l1+l2)----------------------- [1, 2, 3, 4, 5, 6, 7, 8]
3. Membership:- It returns true if a particular item exists in a particular list otherwise false.
⢠Ex- print(2 in l1) ---------------True.
4. Iteration:- The for loop is used to iterate over the list elements.
⢠for i in l1:
print(i)
⢠Output
1
2
3
4
5. Length It is used to get the length of the list
⢠Print( len(l1)) ---------------------------- 4
12.
Built in functionin list
⢠Python has a set of built-in methods that you can use on lists
1 dir():-
We can see the built in methods using the dir() function
Ex:-print(dir(list))
13.
2.help() :- ThePython help() function is used to display the documentation of modules,
functions
EX:-Print(help(list.append))
3. append():-The Python List append() method is used for appending and adding elements to the
end of the Python List.
syntax:- append(add element name)
list1=[1,2,3,4,5]
Print(list.appent(12))---------------[1,2,3,4,5,12]
4.count() :
⢠Python List count() :- this method returns the count of how many times a given object occurs
in a List using python.
⢠Syntax: list_name.count(object)
⢠List1=[1,2,3,4,5,1,2,5,6,3]
⢠Print(List1.count(2))----------------output:-2
14.
5. insert():
⢠Insertingan element at a particular place into a list is one of the essential
operations when working with lists
⢠Syntax:- list_name.insert (index, element)
⢠A=[1,2,3,4,]
⢠Print(A.insert(2,âhiiiâ)----------output A[1,2,hiii,4]
6. reverse():
⢠Python List reverse() is an inbuilt method in the Python language that
reverses objects of the list.
⢠Syntax :list_name.reverse ()
A=[1,2,3,4,5]
print(A.reverse())
15.
7.sort():
⢠Python listsort() function can be used to sort List with Python in ascending,
descending order
⢠Syntax :List_name.sort ()
⢠A=[10,5,7,1,2,3,4,5]
⢠Print(A.sort())
⢠Print(a.sort(reverse=True))
8.len():-The Python List len() method is used to compute the size of a Python List
⢠Syntax:- len(list)
⢠Print(len(A))
16.
Tuple:
a)Creating tuple, Accessingvalue in tuple , deleting value in tuple,
updating value in tuple
b) Basic tuple operations
c) built in tuple functions
17.
Tuple:
An object oftuple allows us to store multiple values of same type or different type or both types.
An object of tuple type allows us to organize both unique and duplicate values.
The elements of tuple must be enclosed within Braces ( ) and the values must be separated by comma (,)
⢠Creating tuple:
⢠tuple of integers
⢠a = (1, 2, 3, 4, 5,1)
⢠# of tuple strings
⢠b = ('apple', 'banana', 'cherryâ)
⢠# Mixed data types
⢠c = (âPWPâ, âMADâ, 6, 20, â PWPâ)
⢠print(a)
⢠print(b)
⢠print(c)
Updating tuple:-
⢠Oncea tuple is created, you cannot change its values. Tuples are unchangeable,
or immutable as it also is called
⢠But there is a workaround. You can convert the tuple into a list, change the list,
and convert the list back into a tuple
⢠x = ("apple", "banana", "cherry")
y = list(x)
y[1] = "kiwi"
x = tuple(y)
print(x)
21.
Deleting Tuple
⢠Tuplesare immutable, you cannot delete individual elements from a tuple
⢠But you can delete an entire tuple using the del keyword
⢠If you try to print a tuple after deleting it, you will receive an error because the
tuple no longer exists.
⢠Ex:
⢠thistuple = ("apple", "banana", "cherry")
⢠del thistuple
⢠print(thistuple) #this will raise an error because the tuple no longer exists
22.
Python Tuple Operations
â˘Consider a tuple l1 = (1, 2, 3, 4) and l2 = (5, 6, 7, 8)
1.Repetition:- The repetition operator enables the tuple elements to be repeated
multiple times.
⢠EX- a=l1*2
⢠print(a)-------------------(1, 2, 3, 4, 1, 2, 3, 4)
2. Concatenation:- It concatenates the list mentioned on either side of the
operator.
⢠Ex- b=l1+l2
⢠print(b)----------------------- [1, 2, 3, 4, 5, 6, 7, 8]
23.
l1 = (1,2, 3, 4)
3. Membership:- It returns true if a particular item exists in a particular tuple otherwise
false.
⢠Ex- print(2 in l1) ---------------True.
4. Iteration:- The for loop is used to iterate over the tuple elements.
⢠for i in l1:
print(i)
⢠Output
1
2
3
4
5. Length It is used to get the length of the tuple
⢠Print( len(l1)) ---------------------------- 4
24.
Tuple built infunction
1. The sorted() Function
⢠This method takes a tuple as an input and returns a sorted list as an output. Moreover, it does
not make any changes to the original tuple
⢠>>> tup = (22, 3, 45, 4, 2.4, 2, 56, 890, 1)
⢠>>> sorted(tup)
⢠[1, 2, 2.4, 3, 4, 22, 45, 56, 890]
2. min():-min(): gives the smallest element in the tuple as an output. Hence, the name is min().
⢠>>> tup = (22, 3, 45, 4, 2.4, 2, 56, 890, 1)
⢠>>> max(tup)-------------------------output:-890
25.
3. max(): givesthe largest element in the tuple as an output. Hence, the name is
max()
⢠>>> tup = (22, 3, 45, 4, 2.4, 2, 56, 890, 1)
⢠>>> max(tup)----------------------output:-890
4. Sum():-gives the sum of the elements present in the tuple as an output
⢠>>> tup = (22, 3, 45, 4, 2, 56, 890, 1)
⢠>>> sum(tup)---------------------------1023
26.
Set
a) Accessing valuesin set, deleting values in set, Updating sets
b) Basic set operations
c) Built-in set functions
27.
⢠Sets areused to store multiple items in a single variable.
⢠Sets do not support indexing
⢠A set is a collection which is unordered, unchangeable, and unindexed
⢠Unordered means that the items in a set do not have a defined order
⢠The elements of the set can not be duplicate.
⢠The elements of the python set must be immutable.
⢠The values False ,True and 0,1 are considered the same value in sets,
and are treated as duplicates
⢠Set declared with curly braces
28.
Creating a set
â˘Example 1:
Days = {"Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday",
"Sunday"}
print(Days)
29.
Accessing set values:weaccess value from set using for loop
⢠Days = {"Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"}
for i in Days:
print(i)
⢠Output:
⢠Friday
⢠Tuesday
⢠Monday
⢠Saturday
⢠Thursday
⢠Sunday
⢠Wednesday
30.
Updating set
⢠Removingitems from the set
⢠Following methods used to remove the items from the set
⢠1. discard
⢠2. remove
⢠3. pop
31.
discard() method
⢠discard()method Python provides discard() method which can be used to remove
the items from the set.
⢠Months ={ "January","February", "March", "April", "May", "Juneâ}
⢠Months.discard("January");
⢠Months.discard("May");
⢠Output:-
⢠{'February', 'March', 'April', 'June'}
32.
remove() method: methodPython provides remove() method which
can be used to remove the items from the set
⢠thisset = {"apple", "banana", "cherry"}
⢠thisset.remove("banana")
⢠print(thisset)
⢠output:
⢠{"appleâ, "cherry"}
33.
difference between removeand discard
⢠The discard() method removes the specified item from the set. This
method is different from the remove() method, because the remove()
method will raise an error if the specified item does not exist, and the
discard() method will not
34.
pop() method
⢠thepop(), method to remove an item, but this method will remove the last item.
Remember that sets are unordered, so you will not know what item that gets
removed
⢠Note: Sets are unordered, so when using the pop() method, you will not know
which item that gets removed
⢠thisset = {"apple", "banana", "cherry"}
⢠x = thisset.pop()
⢠print(x)
⢠print(thisset)
⢠output:
⢠apple
⢠{'cherry', 'banana'
35.
delete the set
â˘The del keyword will delete the set completely:
⢠thisset = {"apple", "banana", "cherry"}
⢠del thisset
⢠print(thisset)
⢠output:
⢠File "demo_set_del.py", line 5, in print(thisset) #this will raise an error because the set no
longer exists NameError: name 'thisset' is not defined
36.
Adding items tothe set
⢠add() method
⢠update() method.
37.
add() method
⢠Pythonprovides the add() method which can be used to add some particular
item to the set
⢠Months = {"January","February", "March", "April", "May", "Juneâ}
⢠Months.add("July");
⢠Months.add("August");
⢠print(Months)
⢠output:
⢠{'February', 'July', 'May', 'April', 'March', 'August', 'June', 'January'}
38.
update() method.
Python providesthe update() method which can be used to add
multiple element to the set
⢠Months = {"January","February", "March", "April", "May", "Juneâ}
Months.update(["July","August","September","Octoberâ]);
⢠print(Months)
⢠output:
⢠{'January', 'February', 'April', 'August', 'October', 'May', 'June', 'July', 'September', 'March'}
In Python, belowquick operands can be used for different operations
⢠| for union.
⢠& for intersection.
⢠â for difference
⢠^ for symmetric difference
41.
⢠Set union:-
â˘The union of two sets is the set of all the elements of both the sets without
duplicates. You can use the union() method or the | operator
⢠Example-1:-
first_set = {1, 2, 3}
second_set = {3, 4, 5}
⢠first_set.union(second_set)----------------------------{1, 2, 3, 4, 5}
⢠Example-2:-
⢠# using the `|` operator
⢠first_set | second_set -----------------------------------------{1, 2, 3, 4, 5}
42.
Set intersection:-The intersectionof two sets is the set of all the common
elements of both the sets. You can use the intersection() method of the &
operator to find the intersection of a Python set.
⢠first_set = {1, 2, 3, 4, 5, 6}
⢠second_set = {4, 5, 6, 7, 8, 9}
⢠first_set.intersection(second_set)------------------------{4, 5, 6}
# using the `&` operator
⢠first_set & second_set---------------------{4, 5, 6}
43.
Set Difference:-
The differencebetween two sets is the set of all the elements in first set that are
not present in the second set. You would use the difference() method or the -
operator to achieve this in Python.
⢠first_set = {1, 2, 3, 4, 5, 6}
⢠second_set = {4, 5, 6, 7, 8, 9}
⢠first_set.difference(second_set)---------------------{1, 2, 3}
⢠# using the `-` operator
⢠first_set - second_set {1, 2, 3}
⢠second_set - first_set---------------------------------{8, 9, 7}
44.
⢠Set SymmetricDifference
⢠The symmetric difference between two sets is the set of all the elements that
are either in the first set or the second set but not in both
⢠You have the choice of using either the symmetric_difference() method or the ^
operator to do this in Python
⢠first_set = {1, 2, 3, 4, 5, 6}
⢠second_set = {4, 5, 6, 7, 8, 9}
⢠first_set.symmetric_difference(second_set)---------------------{1, 2, 3, 7, 8, 9}
⢠# using the `^` operator
⢠first_set ^ second_set------------------------{1, 2, 3, 7, 8, 9}
Dictionary
⢠Dictionary isused to implement the key-value pair in python. The keys are the
immutable python object, i.e., Numbers, string or tuple
⢠Python dictionaries are mutable but key are immutable
⢠Creating the dictionary
⢠The dictionary can be created by using multiple key-value pairs enclosed with the
curly brackets {} and separated by the colon (:).
⢠The collections of the key-value pairs are enclosed within the curly braces {}.
⢠The syntax to define the dictionary is given below.
⢠Dict = {"Name": "Ayush","Age": 22}
Deleting elements usingdel keyword
⢠Employee = {"Name": "John", "Age": 29, "salary":25000,"Company":"GOOGLE"}
⢠del Employee["Name"]
⢠del Employee["Company"]
⢠Output: {'Age': 29, 'salary': 25000}
50.
Dictionary Operations :-
Belowis a list of common dictionary operations:
⢠create an empty dictionary
x = {}
⢠create a three items dictionary
x = {"one":1, "two":2, "three":3}
⢠access an element
x['two']
print(x)-------------------------{2}
⢠get a list of all the keys
x.keys()
print(x)-------------------------{one,two, three}
⢠get a list of all the values
x.values()
print(x)------------------------------{1,2,3}
51.
x = {"one":1,"two":2, "three":3}
⢠add an element
x["four"]=4 ------------------------------- {"one":1, "two":2, "three":3,âfourâ:4}
change an element
x["one"] = âhiiiiâ---------------------{"one":âhiiiâ, "two":2, "three":3,âfourâ:4}
⢠delete an element
del x["four"]----------------------{"one":âhiiiâ, "two":2, "three":3}
remove all items
x.clear() ------------------------------{}
52.
x = {"one":1,"two":2, "three":3}
⢠looping over values
⢠for i in x.values():
print(i)
Output
1
2
3
⢠looping over keys
⢠for I in x.keys():
⢠Print( i)
⢠Output:_
One
two
three