Presentation is loading. Please wait.

Presentation is loading. Please wait.

Module 4 String and list – String traversal and comparison with examples, List operation with example, Tuples and Dictionaries-Operations and examples.

Similar presentations


Presentation on theme: "Module 4 String and list – String traversal and comparison with examples, List operation with example, Tuples and Dictionaries-Operations and examples."— Presentation transcript:

1 Module 4 String and list – String traversal and comparison with examples, List operation with example, Tuples and Dictionaries-Operations and examples

2 Strings A compound data type - Types that comprise smaller pieces
Strings are made up of smaller pieces characters. fruit = "banana“ letter = fruit[1] // index starting from 0 print letter

3 Length The len function returns the number of characters in a string
fruit = "banana" len(fruit) Que : print the last character using len()

4 Traversal and the for loop
processing a string one character at a time Traversal - start at the beginning, select each character in turn, do something to it, and continue until the end.

5 traversal is with a while statement:
index = 0 fruit=“bannana” while index < len(fruit): letter = fruit[index] print letter index = index + 1

6 Traverse with “for” loop
fruit=“bannan” for char in fruit: print char Each time through the loop, the next character in the string is assigned to the variable char. The loop continues until no characters are left

7 concatenation and a for loop to generate an abecedarian series.
“Abecedarian” refers to a series or list in which the elements appear in alphabetical order

8 prefixes = "JKLMNOPQ" suffix = "ack“ for letter in prefixes: print letter + suffix Output Jack Kack Lack Mack Nack Oack Pack Qack

9 String slices A segment of a string is called a slice.
Selecting a slice is similar to selecting a character s = "Peter, Paul, and Mary" print s[0:5] print s[7:11] print s[17:21]

10 [n:m] The operator [n:m] returns the part of the string from the “n-eth” character to the “m-eth” character, including the first but excluding the last.

11 fruit = "banana" fruit[:3] ’ban’ fruit[3:] ’ana’ fruit[:] means?

12 String comparison Equals Less than Grater than

13 Equals word= “Zebra” if word == "banana": print "Yes, we have no bananas!"

14 Other comparison operations
word=“Zebra” if word < "banana": print "Your word," + word + ", comes before banana.“ elif word > "banana": print "Your word," + word + ", comes after banana." else: print "Yes, we have no bananas!"

15 Strings are immutable which means that can’t change an existing string
It is tempting to use the [] operator on the left side of an assignment, with the intention of changing a character in a string. Wrong output greeting = "Hello, world!" greeting[0] = ’J print greeting

16 greeting = "Hello, world!“ newGreeting = ’J’ + greeting[1:] print newGreeting

17 find() str1 = "this is string example....wow!!!"; str2 = "exam";
print str1.find(str2) print str1.find(str2, 10) print str1.find(str2, 40)

18 A find function str=‘character’ def find(str, ch): index = 0 while index < len(str): if str[index] == ch: return index index = index + 1 return -1

19 Looping and counting counts the number of times the letter a appears in a string: fruit = "banana" count = 0 for char in fruit: if char == ’a’: count = count + 1 print count

20 The string module The string module contains useful functions that manipulate strings import string find() fruit = "banana“ index = string.find(fruit, "a") print index can find substrings string.find("banana", "na")

21 it can take two additional arguments that specify a range of indices:
it takes an additional argument that specifies the index it should start at: string.find("banana", "na", 3) it can take two additional arguments that specify a range of indices: string.find("bob", "b", 1, 2)

22 Character classification
to examine a character and test whether it is upper- or lowercase, or whether it is a character or a digit. The string string.lowercase contains all of the letters that the system considers to be lowercase. Similarly, string.uppercase contains all of the uppercase letters.

23 capitalize() isdigit() isalpha() isalnum() islower() isupper isspace()
Built in functions capitalize() isdigit() isalpha() isalnum() islower() isupper isspace()

24 capitalize() It returns a copy of the string with only its first character capitalized. str.capitalize() Example str = "this is string example....wow!!!"; print str.capitalize()

25 isdigit() checks whether the string consists of digits only.
str.isdigit() returns true if all characters in the string are digits and there is at least one character, false otherwise. Example str = "123456"; print str.isdigit() str = "this is string example....wow!!!";

26 isalpha() checks whether the string consists of alphabetic characters only. str.isalpha() returns true if all characters in the string are alphabetic and there is at least one character, false otherwise. Example str = "this"; string print str.isalpha() str = "this is string example....wow!!!"; print str.isalpha()

27 islower() checks whether all the case-based characters (letters) of the string are lowercase. str.islower() returns true if all cased characters in the string are lowercase and there is at least one cased character, false otherwise. Example str = "THIS is string example....wow!!!"; print str.islower() str = "this is string example....wow!!!";

28 isspace() checks whether the string consists of whitespace.
str.isspace() returns true if there are only whitespace characters in the string and there is at least one character, false otherwise. Example str = " "; print str.isspace() str = "This is string example....wow!!!";

29 Lists A list is an ordered set of values, where each value is identified by an index. The values that make up a list are called its elements. The elements of a list can have any type. Lists and strings that behave like ordered sets are called sequences.

30 List values To create a new list; the simplest is to enclose the elements in square brackets ([ and ]): [10, 20, 30, 40] ["spam", "bungee", "swallow"] list contains a string, a foat, an integer, and (mirabile dictu) another list: ["hello", 2.0, 5, [10, 20]]

31 Lists that contain consecutive integers are common so Python provides a simple way to create them: range() range(1,5) The range function takes two arguments and returns a list that contains all the integers from the first to the second, including the first but not including the second! [1, 2, 3, 4]

32 range(10) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] If there is a third argument, it species the space between successive values, which is called the step size. range(1, 10, 2) [1, 3, 5, 7, 9] a special list that contains no elements. It is called the empty list, and it is denoted [].

33 Accessing elements the bracket operator ([]).
The expression inside the brackets species the index the indices start at 0: Ex: numbers = [17, 123] print numbers[0] numbers[1] = 5 The bracket operator can appear anywhere in an expression. When it appears on the left side of an assignment, it changes one of the elements in the list, so the one-eth element of numbers, which used to be 123, is now 5.

34 integer expression can be used as an index numbers = [17, 123]
numbers[1.0] ///Type error read or write an element that does not exist, you get a runtime error: numbers[2] = 5 If an index has a negative value, it counts backward from the end of the list: numbers[-1] 5 numbers[-2] 17 numbers[-3] IndexError: list index out of range

35 use a loop variable as a list index.
horsemen = ["war", "famine", "pestilence", "death"] i = 0 while i < 4: print horsemen[i] i = i + 1

36 List length The function len returns the length of a list
horsemen = ["war", "famine", "pestilence", "death"] i = 0 while i < len(horsemen): print horsemen[i] i = i + 1

37 List membership in is a boolean operator that tests membership in a sequence 1) horsemen = ['war', 'famine', 'pestilence‘] 'pestilence' in horsemen 2) 'debauchery' in horsemen

38 not in 'debauchery' not in horsemen

39 Lists and for loops The generalized syntax of a for loop is:
for VARIABLE in LIST: BODY Example for horseman in horsemen: print horseman

40 Even numbers for number in range(20): if number % 2 == 0: print number

41 for fruit in ["banana", "apple", “orange"]: print "I like to eat " + fruit + "s!"

42 List operations The + operator concatenates lists: a = [1, 2, 3]
b = [4, 5, 6] c = a + b print c

43 * operator * operator repeats a list a given number of times: [0] * 4
[0, 0, 0, 0] [1, 2, 3] * 3 [1, 2, 3, 1, 2, 3, 1, 2, 3]

44 List slices list = ['a', 'b', 'c', 'd', 'e', 'f'] list[1:3] list[:4]

45 Lists are mutable can change the list elements.
Using the bracket operator on the left side of an assignment we can update one of the elements: fruit = ["banana", "apple", "quince"] fruit[0] = "pear“ fruit[-1] = "orange“ print fruit

46 2 list = ['a', 'b', 'c', 'd', 'e', 'f'] list[1:3] = ['x', 'y'] print list

47 remove elements from a list by assigning the empty list to them
list = ['a', 'b', 'c', 'd', 'e', 'f'] list[1:3] = [] print list ['a', 'd', 'e', 'f']

48 Adding elements can add elements to a list by squeezing them into an empty slice at the desired location: list = ['a', 'd', 'f'] list[1:1] = ['b', 'c'] print list Output ['a', 'b', 'c', 'd', 'f'] list[4:4] = ['e'] ['a', 'b', 'c', 'd', 'e', 'f']

49 List deletion del removes an element from a list:
a = ['one', 'two', 'three'] del a[1] print a

50 del handles negative indices and causes a runtime error if the index is out of range.
1) list = ['a', 'b', 'c', 'd', 'e', 'f'] del list[1:5] print list 2) list = ['a', 'b', 'c', 'd', 'e', 'f'] del list[-1]

51 3 list = ['a', 'b', 'c', 'd', 'e', 'f'] del list[-6:-2] print list

52 Aliasing Since variables refer to objects, if assign one variable to another, both variables refer to the same object: a = [1, 2, 3] b = a

53

54 the same list has two different names, a and b, we say that it is aliased.
Changes made with one alias affect the other b[0] = 5 print a

55 Cloning lists If we want to modify a list and also keep a copy of the original, we need to be able to make a copy of the list itself, not just the reference. This process is sometimes called cloning easiest way to clone a list is to use the slice operator: a = [1, 2, 3] b = a[:] print b

56 b[0] = 5 print a

57 List parameters Passing a list as an argument actually passes a reference to the list, not a copy of the list. def head(list): return list[0] numbers = [1, 2, 3] x=head(numbers) print x the function head takes a list as an argument and returns the first element

58 Delete def deleteHead(list): del list[0] numbers = [1, 2, 3]
deleteHead(numbers) print numbers

59 If a function returns a list, it returns a reference to the list.
def tail(list): return list[1:] numbers = [1, 2, 3] rest = tail(numbers) print rest

60 Nested lists A nested list is a list that appears as an element in another list list = ["hello", 2.0, 5, [10, 20]] print list[3], //[10, 20]. To extract an element from the nested list, we can proceed in two steps: elt = list[3] elt[0] Or we can combine them: list[3][1] 20

61 Matrices Nested lists are often used to represent matrices
might be represented as: matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] where matrix is a list with three elements, where each element is a row of the matrix. matrix[1] [4, 5, 6] matrix[1][1] 5

62 Addition of matrix X = [[1, 2], [4, 5], [3, 6]] would represent a 3x2 matrix. First row can be selected as X[0] and the element in first row, first column can be selected as X[0][0].

63 Tuples similar to a list except that it is immutable.
a tuple is a comma-separated list of values Ex: tuple = 'a', 'b', 'c', 'd', 'e‘ not necessary, it is conventional to enclose tuples in parentheses: tuple = ('a', 'b', 'c', 'd', 'e') To create a tuple with a single element, we have to include the final comma t1 = ('a',) Without the comma, Python treats ('a') as a string in parentheses: t2 = ('a')

64 Advantages of Tuple over List
use tuple for heterogeneous (different) datatypes and list for homogeneous (similar) datatypes. Since tuple are immutable, iterating through tuple is faster than with list implementing it as tuple will guarantee that it remains write-protected.

65 Operations The index operator selects an element from a tuple
1) tuple = ('a', 'b', 'c', 'd', 'e') tuple[0] // 'a‘ 2) Negative indexing tuple = ('a', 'b', 'c', 'd', 'e') tuple[-1]

66 The slice operator selects a range of elements tuple[1:3]
3) Slicing The slice operator selects a range of elements tuple[1:3] ('b', 'c') if we try to modify one of the elements of the tuple, we get an error: tuple = ('a', 'b', 'c', 'd', 'e') tuple[0] = 'A'

67 even if we can't modify the elements of a tuple, we can replace it with a different tuple:
tuple = ('a', 'b', 'c', 'd', 'e') tuple = ('A',) + tuple[1:] print tuple ('A', 'b', 'c', 'd', 'e')

68 Tuple assignment To swap values of 2 variables
a, b = b, a The left side is a tuple of variables; the right side is a tuple of values. Each value is assigned to its respective variable. All the expressions on the right side are evaluated before any of the assignments The number of variables on the left and the number of values on the right have to be the same a, b, c, d = 1, 2, 3 //error

69 Tuple Methods Count(x) - Return the number of items that is equal to x
index(x) -- Return index of first item that is equal to x

70 Example tup=('a','p','p','l','e') x=tup.count('p') print xy=tup.index('l') print y

71 Iterating Through a Tuple
Using a for loop we can iterate though each item in a tuple. for name in ('John','Kate'): print "Hello",name Output 'Hello', 'John'                                                            'Hello', 'Kate'


Download ppt "Module 4 String and list – String traversal and comparison with examples, List operation with example, Tuples and Dictionaries-Operations and examples."

Similar presentations


Ads by Google