1、为什么需要生成器?
通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。
所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间。在Python中,这种一边循环一边计算的机制,称为生成器:generator。
————来源:廖雪峰Python教程
2、利用列表生成的方法创建一个列表和生成器
#列表
d = [x for x in range(1,12)]
#生成器
g = (x for x in range(1,12))
可以用type函查看 d 和 g的类型 ,d是 list,g是generator
3、对于生成器来说,保存的是算法,而不是数据本身,可以用next(g)来计算去生成器的下一个函数值,同样生成器是可以迭代的所以可以用for循环来进行迭代,例如:
#生成器的迭代
g = (x for x in range(1,12))
for i in g:
print(i)
4、元素一旦定义完成,内部的数据是无法改动的,而生成器内部的数据可以发生变化
5、定义generator的另一种方法:如果一个函数定义中包含yield
关键字,那么这个函数就不再是一个普通函数,而是一个generator:
def fib(max):
n, a, b = 0, 0, 1
while n < max:
yield b
a, b = b, a + b
n = n + 1
return 'done'