愿你一直充滿無限的潛力
列表推導(dǎo)式
>>> [x+1 for x in range(10) ]
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
從上面的代碼可以看出,列表推導(dǎo)式是生成一個列表坠宴。
生成器
>>> g=(x+1 for x in range(10))
>>> g
<generator object <genexpr> at 0x7f3af91b7570>
>>> next(g)
1
>>> next(g)
2
>>> next(g)
3
>>> next(g)
4
>>> next(g)
5
>>> next(g)
6
>>> next(g)
7
>>> next(g)
8
>>> next(g)
9
>>> next(g)
10
>>> next(g)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
StopIteration
>>>
從上面的代碼可以看出,生成器的形式和列表推導(dǎo)式差不多绷旗,只是括號的不同喜鼓。
本質(zhì)區(qū)別是列表推導(dǎo)式是一次性生成,而生成器是通過相應(yīng)的算法推導(dǎo)出來的值衔肢,在數(shù)據(jù)量較大的時候庄岖,你不可能一次性生成那么大的列表,生成器是最好的選擇角骤。
例如:用生成器產(chǎn)生斐波拉契數(shù)列
def fibs(max):
n,a,b=0,0,1
while n < max:
yield b
a,b = b,a+b
n+=1
for n in fibs(6):
print(n)