可迭代对象、迭代器、for循环本质
一. 可迭代对象
1. 迭代
迭代即更新换代 每次的更新都必须依赖于上一次的结果
迭代其实给我们提供了一种不依赖索引取值的方式
2. 可迭代对象
内置有__iter__方法的都称之为可迭代对象
内置的意思是可以通过点的方式直接查看到的
针对双下滑线开头 双下滑线结尾的方法 最为专业标准的读法为
双下方法名
面向对象的时候为了与隐藏变量区分开
i = 12 # 没有__iter__
f = 11.11 # 没有__iter__
s = 'jason' # 有__iter__
l = [111,22,33,4] # 有__iter__
d = {'username':'jason','pwd':123} # 有__iter__
t = (11,22,33) # 有__iter__
se = {11,22,33} # 有__iter__
b = True # 没有__iter__
file = open(r'a.txt','w',encoding='utf8') # 有__iter__
含有__iter__的有
字符串 列表 字典 元组 集合 文件对象
上述通常为可迭代对象
可迭代对象调用__iter__方法会变成迭代器对象(老母猪)
3. 迭代器对象
"""
迭代器对象
即含有__iter__方法 又含有__next__方法
如何生成迭代器对象
让可迭代对象执行__iter__方法
文件对象本身即是可迭代对象又是迭代器对象
迭代器对象无论执行多少次__iter__方法 还是迭代器对象(本身)
迭代器给我们提供了不依赖于索引取值的方式
"""
i = 12 # 没有__iter__
f = 11.11 # 没有__iter__
s = 'jason' # 转迭代器前没有__next__
l = [111,222,333,444] # 转迭代器前没有__next__
d = {'username':'jason','pwd':123} # 转迭代器前没有__next__
t = (11,22,33) # 转迭代器前没有__next__
se = {11,22,33} # 转迭代器前没有__next__
b = True # 没有__iter__
file = open(r'a.txt','w',encoding='utf8') # 有__next__
res = d.__iter__() # 转成迭代器对象
print(res.__next__()) # 迭代器对象执行__next__方法其实就是在迭代取值(for循环)
print(res.__next__())
print(res.__next__()) # 取完元素之后再取会"报错"
4. for循环的本质
for循环内部原理
1.将关键字in后面的数据先调用_ _ iter _ _方法转为迭代器对象
2.循环执行 _ _ next _ _ 方法
3.取完之后 _ _ next _ _ 会报错 但是for循环会自动捕获该错误并处理
res = 数据.__iter__()
while True:
检测代码是否会报错
res.__next__()
如果报错了则自动处理掉并结束while循环