1.生成器
在Python中创建迭代器最方便的技术是生成器。顾名思义,生成器的作用是生成,他的特点就是根据需要生成,避免一次性生成大量元素占用内存。生成器的语法实现类似于函数,但是不返回值。yield语句显示序列中的每一个元素。1
2.生成器的实现
传统函数的对比。
例如,数字100有因子,1,2,4,5,10,20,25,50,100。
传统方法:
def factors(n):
results = []
for k in range(1,n+1):
if n%k == 0:
results.append(k)
return results
print(factors(100))
产生的结果:
[1, 2, 4, 5, 10, 20, 25, 50, 100]
生成器法:
def factors(n):
for k in range(1, n+1):
if n%k == 0:
yield k
print(factors(100))
产生的结果:
<generator object factors at 0x000001FF100860C8>
注意:
我们使用yield而不是return来表示结果。这表明在python中我们正在定义一个生成器,而不是传统函数。并且在同一函数中,将yield和return结合是非法的。
从传统方法和生成器法的代码中可以总结出:
传统方法产生的结果会存放在一个列表中。列表所有数据都在内存中,如果有海量数据的话将会非常耗费内存。生成器法的结果<generator object factors at 0x000001FF100860C8>此举只是将生成器放在了内存中,在需要用到时候再调出。
本文参考
https://blog.csdn.net/weixin_37720172/article/details/78482291从博主的思路清晰,讲述简明的写作中学到了很多。 ↩︎