迭代器

迭代器

迭代器:不是函数,只是一个称呼而已

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__依然是迭代器

# 可迭代对象不一定是迭代器对象; 迭代器对象一定是可迭代对象
原文地址:https://www.cnblogs.com/jzm1201/p/12595292.html