迭代器

来源:互联网 发布:侯振挺落选院士 知乎 编辑:程序博客网 时间:2024/06/06 23:58

迭代器

  • 什么是迭代和迭代器

​ 迭代是访问集合元素的一种方式,迭代器是一个可以记住遍历的位置的对象。

​ 迭代器对象从集合的以一个元素开始访问,直到所有的元素被访问完结束。

​ 迭代器只能往前不会后退

  • 可迭代的对象

    以直接作用于for循环的数据类型有以下几种:

    • 集合类数据类型,list、tuple、dict、set、str
    • 一类是generator,包括生成器和带yield的generator function

    这些可以直接作用于for循环的对象统称为可迭代对象:Iterable

  • 判断是否可以迭代

    可以使用isinstance()来判断一个对象是否是Iterable对象:

    In [17]: from collections import IterableIn [18]: isinstance([],Iterable)Out[18]: TrueIn [19]: isinstance({},Iterable)Out[19]: TrueIn [20]: isinstance((1,),Iterable)Out[20]: TrueIn [21]: isinstance("abc",Iterable)Out[21]: TrueIn [22]: isinstance((x for x in range(10)),Iterable)Out[22]: TrueIn [23]: isinstance(110,Iterable)Out[23]: FalseIn [24]: 

    ​ 生成器不但可以作用于for循环,还可以被next()函数不断调用并返回下一个值,直到最后抛出StopIteration异常就表示无法继续下一个值了。

  • 迭代器

    ​ 可以被next()函数调用并不断返回下一个值的对象称之为迭代器:Iterator

    ​ 可以使用isinstance()来判断一个对象是否是Iterator对象:

    In [25]: from collections import IteratorIn [26]: isinstance([],Iterator)Out[26]: FalseIn [27]: isinstance({},Iterator)Out[27]: FalseIn [28]: isinstance((),Iterator)Out[28]: FalseIn [29]: isinstance("abcd",Iterator)Out[29]: FalseIn [30]: isinstance(110,Iterator)Out[30]: FalseIn [31]: isinstance((x for x in range(10)),Iterator)Out[31]: TrueIn [32]: 
  • iter()函数

    ​ 生成器都是Iterator对象,但是list、dict、str虽然是Iterable,却不是Iterator

    ​ 可以通过iter()函数将list、dict、str等Iterable转成Iterator

    In [37]: isinstance(iter([]),Iterator)Out[37]: TrueIn [38]: isinstance(iter("abcd"),Iterator)Out[38]: True

  • 总结
    • 凡是可作用于 for 循环的对象都是 Iterable 类型;
    • 凡是可作用于 next() 函数的对象都是 Iterator 类型
    • 集合数据类型如 list 、 dict 、 str 等是 Iterable 但不是 Iterator ,不过可以通过 iter() 函数获得一个 Iterator 对象。