day17
try:
被监测的代码
except 错误类型 as e:
...
else:
被监测的代码不报错的时候执行
finally:
无论是否报错最终
d = {'name':'jason','pwd':123,'hobby':'read'}
res = d.__iter__() # StopIteration
while True:
try:
print(res.__next__())
except StopIteration as e:
break
for i in d:
print(i)
迭代取值
优点: 不依赖于索引的一种通用取值方式
缺点: 取值的顺序永远都是固定的从左往右 无法重复获取
索引取值
缺点: 需要提供有序容器类型才可取值(不是一种通用的方式)
优点: 可以重复取值
l = [11,22,33,44,55,66] 方式1 res = [i+1 for i in l] print(res) 方式2 res1 = (i+1 for i in l ) print(res1.__next__()) 生成器表达式内部的代码只有在迭代取值的时候才会执行
常见内置函数
l = [11, 22, 33, 44, 55, 66, 77, 88, 99] # res = [i+1 for i in l if i!=44] # print(res) # res1 = (i+1 for i in l if i!=44) """ 生成器表达式内部的代码只有在迭代取值的时候才会执行 """ # print(res1.__next__()) # print(res1.__next__()) # print(res1.__next__()) """ 迭代器对象 生成器对象 我们都可以看成是"工厂" 只有当我们所要数据的时候工厂才会加工出"数据" 上述方式就是为了节省空间 """ # 求和 def add(n, i): return n + i # 调用之前是函数 调用之后是生成器 def test(): for i in range(4): yield i g = test() # 初始化生成器对象 for n in [1, 10]: g = (add(n, i) for i in g) """ 第一次for循环 g = (add(n, i) for i in g) 第二次for循环 g = (add(10, i) for i in (add(10, i) for i in g)) """ res = list(g) print(res) #A. res=[10,11,12,13] #B. res=[11,12,13,14] #C. res=[20,21,22,23] #D. res=[21,22,23,24]

浙公网安备 33010602011771号