区分不开列表,字典集合等非迭代器对象与迭代器对象的区别,迭代器不能是多余的。
首先,创建一个列表 a:
a = [1,3,5,7]
有没有朋友认为列表就是迭代器的?
注意:列表 a 可不是迭代器(iterator)。
要想成为迭代器,需要经过内置函数 iter 包装:
a_iter = iter(a)
此时 a_iter 就是Iterator,迭代器。可以验证:
: from collections.abc import Iterator
: isinstance(a_iter,Iterator)
: True
分别遍历 a , a_iter:
: for i in a:
print(i)
1
3
5
7
: for i in a_iter:
print(i)
1
3
5
7
打印结果一样
但是,再次遍历 a , a_iter, 就会不同
a 正常打印,a_iter没有打印出任何元素
: for i in a:
print(i)
1
3
5
7
: for i in a_iter:
print(i)
这就是列表 a 和迭代器 a_iter的区别:
- 列表不论遍历多少次,表头位置始终是第一个元素
- 迭代器遍历结束后,不再指向原来的表头位置,而是为最后元素的下一个位置
只有迭代器对象才能与内置很熟 next 结合使用, next 一次,迭代器就前进一次,指向一个新的元素。
所以,要向迭代器 a_iter 重新指向 a 的表头,需要重新创建一个新的迭代器 a_iter_copy
: a_iter_copy = iter(a)
调用 next 输出迭代器指向 a 的第一个元素:
:next(a_iter_copy)
: 1
值得注意的是,我们无法通过调用 len 获取迭代器的长度,只能地阿呆最后一个末尾元素时,才知道长度。
可问题是,我们怎么知道迭代到末尾元素呢?
我们一直 next,看看会发生什么:
: next(a_iter_copy)
: 3
: next(a_iter_copy)
: 5
: next(a_iter_copy)
: 7
: next(a_iter_copy)
: StopIteration
等迭代到最后一个元素后,再执行 next ,会触发 StopIteration 异常
所以,通过捕获此异常,就能求出迭代器指向 a 的长度
总结:
- 遍历列表,表头位置始终不变;遍历迭代器,表头位置相应改变
- next 函数之星一次,迭代对象指向就前进一次
- StopIteraton 触发时,意味着已到迭代器尾部
看完记得点赞哦,笔芯
网友评论