可迭代对象、迭代器、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循环

image

posted @ 2021-11-19 16:27  zong涵  阅读(50)  评论(0编辑  收藏  举报