这里用的是python 3.6
可以用yield定义生成器,生成器保存的是算法,每迭代一次,返回一个yield后的值,直到遇到StopIteration,迭代完成,即next指向StopIteration,这个生成器不能再次被迭代
初学不能理解yield的时候,就把yield看成print,只不过print是返回给人看的
,yield是返回给机器的
但我们在用yield定义生成器的时候,又写了return会怎么样
# 遍历这个生成器,遇到return,停止遍历, # 在这里return就是StopIteration def g2(): yield 'a' yield 'b' yield 'c' return yield 'd' for n in g2(): print(n)
# 这个return在我完全迭代完之后, # 所以看上去这个return没影响 def fib(n): a, b = 0, 1 while(n>0): yield a a, b = b, a+b n-=1 return a