迭代器
迭代器:不是函数,只是一个称呼而已
x = 10 # 不是可迭代对象
s = 'abc'
s.__iter__()
lt = [1, 2, 3]
lt.__iter__()
tup = (1,)
tup.__iter__()
dic = {'a': 1}
dic.__iter__()
se = {1}
se.__iter__()
fw = open('test.txt', 'a+', encoding='utf8')
fw.seek(0, 0)
fw.__iter__()
# 除了数字类型,所有数据类型都是可迭代对象
# 迭代器对象: 含有__iter__和__next__方法的对象就是迭代器对象
# 为什么要有迭代器对象:提供了 不依赖索引取值的 手段
#字符串
s = 'abc'
s_iter = s.__iter__()
print(s_iter.__next__()) # a
print(s[0]) # a
print(s_iter.__next__()) # b
print(s[1]) # b
print(s_iter.__next__()) # c
print(s[2]) # c
#字典
dic = {'a': 1, 'b': 2, 'c': 3}
dic_iter=dic.__iter__()
print(dic_iter.__next__()) # a # 迭代取值 --》 基于上一个值
print(dic_iter.__next__()) # b
print(dic_iter.__next__()) # c
# 如果用c写,这就是for循环
# for循环自动捕捉个数,用尽停止
dic_iter = dic.__iter__()
while True:
try:
print(dic_iter.__next__())
except StopIteration:
break
# for循环原理(for循环本质就是一个while循环,只不过是一个一定可控的while循环)
#文件
fw = open('test.txt', 'a+', encoding='utf8')
fw.seek(0, 0)
fw.__iter__()
fw_iter = fw.__iter__()
print(fw_iter.__next__())
print(fw_iter.__next__())
print(fw_iter.__next__())
# 总结
# 可迭代对象: 含有__iter__方法叫做可迭代对象 --> 除了数字类型都是可迭代对象 --> 可迭代对象使用__iter__变成迭代器
# 迭代器对象: 含有__iter__和__next__方法叫做迭代器对象 --> 只有文件时迭代器对象 --> 迭代器使用__iter__依然是迭代器
# 可迭代对象不一定是迭代器对象; 迭代器对象一定是可迭代对象