3. Python 迭代器与生成器

生成器与迭代器

迭代

迭代(Iteration)是一种遍历可迭代类型的方式

  • Python中通过for循环完成迭代
  • for循环作用于一个可迭代对象就可以正常运行

生成器

生成器(generator)是在循环的过程中不断推算出后续的元素的机制

  • 使用了yield的函数被称为生成器
def fib(max):  # 生成器函数 - 斐波那契
    n, a, b = 0, 0, 1
    while n < max:
        yield b
        a, b = b, a + b
        n += 1
    return 'done'
  • 把列表生成式的[]改成(),可创建一个生成器
>>> L = [x * x for x in range(10)]
>>> L
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
>>> g = (x * x for x in range(10))
>>> g
 at 0x0000028404A10518>
  • 通过next()函数获得生成器的下一个返回值,没有更多元素时,返回StopIteration错误
  • 调用一个生成器函数,返回的是一个迭代器对象
  • 调用生成器运行的过程中,遇到yield时函数会暂停并保存当前所有的运行信息,返回yield 的值, 并在下一次执行next()方法时从当前位置继续运行

迭代器

迭代器(Iterator)是可以被next()函数调用并不断返回下一个值的对象,迭代器可记住遍历的位置。

  • 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束
  • 迭代器只能往前不会后退
  • 迭代器有两个基本的方法iter()和next()
  • 生成器都是迭代器对象,list、dict、tuple、str虽是可迭代类型,却不是迭代器
  • 把list、dict、tuple、str等可迭代类型变成迭代器可以使用iter()函数
  • 可作用于for循环的对象都是可迭代类型
  • 可作用于next()函数的对象都是迭代器,表示一个惰性计算的序列
  • 可使用collections模块的Iterator类型判断一个对象是否可迭代
  • 可使用collections模块的Iterable类型判断一个对象是否可迭代
>>> from collections import Iterable
>>> isinstance('abc', Iterable) # str是否可迭代
True
>>> from collections import Iterator
>>> isinstance('abc', Iterator) # str是否为迭代器
False

你可能感兴趣的:(3. Python 迭代器与生成器)