4.if语句
If语句可以检查判定当前条件,并执行相应措施。
1 if a in A: 2 if a 条件: 3 执行命令1 4 else: 5 执行命令2 6 7 if判断条件还可以简写 8 if x: 9 print('True')
只要x是非零数值、非空字符串、非空list等,就判断为True,否则为False。
4.1条件测试(条件判断)
1.每个if语句的核心都是条件判断True或False,这种表达式称为条件测试。
2.Python根据条件测试的值True或False来判断是否执行下面的代码,如果if语句的判断为True,就执行下面代码,判断为False会忽略下面的代码。
3.在python中,任何不为0,Null或空对象的东西都为True。
4.2检查是否相等
1.Python比较大小是区分大小写。
2.!= 表示不相等,感叹号表示不,可以比较数字,字符。
4.3检查多个条件
1.使用关键词and连接,都满足为True,一个没有满足都为False。为改善可读性,可将每个测试写在( )中。
2.使用关键词or连接,满足一个就为True,都不满足才为False。
4.4检查特定的值是否包含在列表中
1.使用关键词in来判断包含关系。
2.使用关键词 not in 来判断不包含关系。
4.5布尔表达式
1.布尔表达式是条件测试的别名,结果一样都是True或False。布尔值和布尔代数的表示完全一致,一个布尔值只有True、False两种值,要么是True,要么是False,在Python中,可以直接用True、False表示布尔值(请注意大小写)
2.布尔值可以用and、or和not运算。布尔操作符。
>>> True and True True >>> True and False False >>> False and False False >>> not True False
4.6if 语句
1.简单if语句,一个测试,一个操作,注意缩进,和冒号。
2.if-else语句 一个条件测试,2个操作。
3.if-elif-else结构 多条件测试,elif是else if的缩写,完全可以有多个elif。
1 if <条件判断1>: 2 <执行1 3 elif <条件判断2>: 4 <执行2> 5 elif <条件判断3>: 6 <执行3> 7 else: 8 <执行4>
4.if语句执行有个特点,它是从上往下判断,如果在某个判断上是True,把该判断对应的语句执行后,就忽略掉剩下的elif和else。
5.可省略else,用elif代替,避免引入更多错误信息。
6.语法格式== 、>= 和<= 等比较运算符两边各添加一个空格,例如,if age < 4: 要比 if age<4: 好。
5.字典
Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。
特点:
1.无序的,字典是动态数据,字典由{ }组成,分号隔开。字典包含键和值,一 一对应。
2.与键相关联的值可以是数字、字符串、列表乃至字典,可将任何Python对象用作字典中的值。
3.正确使用dict非常重要,需要牢记的第一条就是dict的key必须是不可变对象。
set:
1. set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
2.set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作:&交集; | 并集;
3.set和dict的唯一区别仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”。试试把list放入set,看看是否会报错。
4.通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果。
5.通过remove(key)方法可以删除元素。
list和dict对比
和list比较,dict有以下几个特点:
1.查找和插入的速度极快,不会随着key的增加而变慢;
2.需要占用大量的内存,内存浪费多。
而list相反:
1.查找和插入的时间随着元素的增加而增加;
2.占用空间小,浪费内存很少。
所以,dict是用空间来换取时间的一种方法。
5.1访问字典的值
1.键值访问
知道键值可以访问值:
>>> test = {'a': 1, 'b': 2, 'c': 3, 'd': 4} >>> test['a'] 1 >>> test['b'] 2
要避免key不存在的错误,有两种办法,一是通过in判断key是否存在:
>>> 'a' in test True >>> 'b' in test True >>> 'e' in test False
2.get方法
是通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value:
>>>d.get('Thomas') >>>d.get('Thomas', -1) #在d中不存在'Thomas',返回-1 -1 >>> picnicItems = {'apples': 5, 'cups': 2} >>> 'I am bringing ' + str(picnicItems.get('cups', 0)) + ' cups.' 'I am bringing 2 cups.' >>> 'I am bringing ' + str(picnicItems.get('eggs', 0)) + ' eggs.' 'I am bringing 0 eggs.
注意:返回None的时候Python的交互式命令行不显示结果。
3.setdefault()方法
setdefault()方法提供了一种方式,在一行中完成这件事。传递给该方法的第一个参数,是要检查的键。第二个参数,是如果该键不存在时要设置的值。如果该键确实存在,方法就会返回键的值。
>>> spam = {'name': 'Pooka', 'age': 5} >>> spam.setdefault('color', 'black') #键不存在,返回'black' 'black'
4.pprint 模块
导入 pprint 模块,就可以使用 pprint()和pformat()函数,它们将“漂亮 打印”一个字典的字。
pprint.pprint(someDictionaryValue) print(pprint.pformat(someDictionaryValue))
5.2添加键和值
字典是动态数据,可以随时在其中添加键和值,通过key加入数据:
1 alien_0 = {'color': 'green', 'points': 5} 2 alien_0['x_position'] = 0 3 alien_0['y_position'] = 25 4 print(alien_0)
5 {'color': 'green', 'points': 5, 'x_position': 0, 'y_position': 25}
5.3删除键和值
1.要删除一个key,用pop(key)方法,对应的value也会从dict中删除:
>>> test = {'a': 1, 'b': 2, 'c': 3, 'd': 4} >>> test.pop('a') 1 >>> test {'b': 2, 'c': 3, 'd': 4}
2.使用del :
>>> del test['c'] >>> test {'b': 2, 'd': 4}
5.4遍历字典 item()
Python 字典(Dictionary) items() 函数以列表返回可遍历的(键, 值) 元组数组。
for key, value in user_0.items():
实际:
for name, language in favorite_languages.items():
简单变量名:
for k, v in user_0.items()
注意,即便遍历字典时,键—值对的返回顺序也与存储顺序不同。Python不关心键—值对的存储顺序,而只跟踪键和值之间的关联关系。
判断一个对象是可迭代对象,方法是通过collections模块的Iterable类型判断;
>>> from collections import Iterable >>> isinstance('abc', Iterable) # str是否可迭代
Python内置的enumerate函数可以把一个list变成索引-元素对,这样就可以在for循环中同时迭代索引和元素本身。
使用内建的isinstance函数可以判断一个变量是不是字符串。
5.4.1遍历字典所有的键(for循环)
Python的循环有两种,一种是for...in循环,依次把list或tuple中的每个元素迭代出来,看例子:
for name in favorite_languages.keys():
遍历字典时,会默认遍历所有的键,因此,如果将上述代码中的for name in favorite_languages.keys(): 替换为for name in favorite_languages: ,输出将不变。 如果显式地使用方法keys() 可让代码更容易理解,你可以选择这样做,但如果你愿意,也可省略它。
5.4.2按顺序遍历字典所有的键
sorted()
使用函数sorted() 来获得按特定顺序排列的键列表的副本。
按首字母排序:
一种办法是在for 循环中对返回的键进行排序。为此,可使用函数sorted() 来获得按特定顺序排列的键列表的副本。
5.4.3遍历字典中所有的值
values()
使用方法values() ,它返回一个值列表,而不包含任何键。
for language in favorite_languages.values():
为剔除重复项,可使用集 合set()。集合 类似于列表,但每个元素都必须是独一无二的:
for language in set(favorite_languages.values()):
5.5嵌套
还可以使用两层循环,可以生成全排列。
>>> a = [1, 2, 3] >>> for n in a: ... for m in a: ... print(n, m) ... 1 1 1 2 1 3 2 1 2 2 2 3 3 1 3 2 3 3
5.5.1字典列表
1 alien_0 = {'color': 'green', 'points': 5} 2 alien_1 = {'color': 'yellow', 'points': 10} 3 alien_2 = {'color': 'red', 'points': 15} 4 aliens = [alien_0, alien_1, alien_2]
5.5.2在字典中存储字典
字典中嵌套字典
5.6退出循环(break)
在循环中,break语句可以提前退出循环。这个语句通常必须配合if语句使用。
5.7continue
在循环过程中,也可以通过continue语句,跳过当前的这次循环,直接开始下一次循环。这个语句通常也必须配合if语句使用。