Python生成器generator和yield關(guān)鍵字的使用
Python生成器generator和yield關(guān)鍵字

生成器 generator 是一個返回迭代器的函數(shù),只能用于迭代操作,更簡單點(diǎn)理解生成器就是一個迭代器。
實現(xiàn)生成器有兩種方式:
第一:將列表推導(dǎo)式種的 [] 改成 ()
a=[[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], ["a","b","c","d","e","f","g","h","i","j"], ["A","B","C","D","E","F","G","H","I","J"]] res=(tmp for ele in a for tmp in ele ) type(res)
可以看出 res 已經(jīng)是一個生成器了

那么使用生成器有什么用途呢?
1)迭代器能做的,它也能做,例如 next() 方法

2) 也可以使用 for 循環(huán)

3)最重要的是,它是隨用隨取的,不會像列表生成式 [] 那樣一下子全生成,只是在迭代時候才會生成(雖然對于用戶而言,遍歷時候可能感受不到)。
第二:使用 yield 關(guān)鍵字
yield 關(guān)鍵字是很特殊的,一個函數(shù)里有了 yield 后,執(zhí)行到 yield 就會停住,下載再次調(diào)用時繼續(xù)從上一次中斷的位置繼續(xù)執(zhí)行代碼并返回值。所以生成器函數(shù)即使是有無限循環(huán)也沒關(guān)系,它需要算到多少就會算多少,不需要就不往下算。
請注意,有 yield 關(guān)鍵字的函數(shù)不是生成器,是該函數(shù)的運(yùn)行結(jié)果是一個生成器!
先說說最簡單的情況
我先創(chuàng)建一個函數(shù) f ,依次生成100以內(nèi)的數(shù), 使用 type 函數(shù)可以看到這是一個 function
def f():
i=0
yield i
while(i<100):
i+=1
yield i
那么執(zhí)行這個函數(shù)呢
res=f()type(res)
這個函數(shù)執(zhí)行的結(jié)果是一個生成器!

對這個返回的生成器,可以使用 next() 方法

使用生成器解決實際問題,例如常見的斐波拉契數(shù)列。
斐波拉契數(shù)列:指的是這樣一個數(shù)列:1、1、2、3、5、8、13、21、34、……在數(shù)學(xué)上,斐波那契數(shù)列以如下被以遞推的方法定義:F(0)=0,F(xiàn)(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)
1) 一個簡單的無線循環(huán)的 fib 生成器
def fib():
a=[0,1]
yield a[0]
yield a[1]
while True:
tmp=a[0]+a[1]
a=[a[1],a[0]+a[1]]
yield tmp運(yùn)行結(jié)果是

2)一個有限循環(huán)的(n 次數(shù))的 fib 生成器
def fib(n):
i=0
a,b=0,1
yield a
while(i<n):
a,b=b,a+b
i+=1
yield a運(yùn)行結(jié)果如下,當(dāng)?shù)螖?shù)小于等于 n 時候,可以輸出相應(yīng)的數(shù)列數(shù),大于 n 時候則報錯。

3)斐波拉契數(shù)列的一個變形,即返回包含前 n 個 數(shù)的列表
理論上1)2) 都可以實現(xiàn),但是有一個額外要求,即不需要反復(fù)去從 1 計算起。
使用 1) 中無限循環(huán)函數(shù)
%%time
# 一個簡單的無線循環(huán)的,生成fib 數(shù)列的生成器
def fib():
a=[0,1]
yield a[0]
yield a[1]
while True:
tmp=a[0]+a[1]
a=[a[1],a[0]+a[1]]
yield tmp
# 只要前 n 個 fib 數(shù)字
i=0
n=10
res=[]
gen=fib()
# 簡單的 while 循環(huán) 因為使用next 不需要重復(fù)計算
while(i<n):
res.append(next(gen))
i+=1
res
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python基于多線程操作數(shù)據(jù)庫相關(guān)問題分析
這篇文章主要介紹了Python基于多線程操作數(shù)據(jù)庫相關(guān)問題,結(jié)合實例形式分析了Python使用數(shù)據(jù)庫連接池并發(fā)操作數(shù)據(jù)庫避免超時、連接丟失相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2018-07-07
python實現(xiàn)字典合并的五種方法(附示例代碼)
在Python中,有多種方法可以通過使用各種函數(shù)和構(gòu)造函數(shù)來合并字典,在本文中,我們將討論一些合并字典的方法,并通過代碼示例講解的非常詳細(xì),具有一定的參考價值,需要的朋友可以參考下2024-04-04
利用 PyCharm 實現(xiàn)本地代碼和遠(yuǎn)端的實時同步功能
這篇文章主要介紹了利用 PyCharm 實現(xiàn)本地代碼和遠(yuǎn)端的實時同步功能,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03
詳解Python函數(shù)可變參數(shù)定義及其參數(shù)傳遞方式
這篇文章主要介紹了詳解Python函數(shù)可變參數(shù)定義及其參數(shù)傳遞方式的相關(guān)資料,這里提供實例代碼幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08
Python生成指定數(shù)量的優(yōu)惠碼實操內(nèi)容
在本篇文章里小編給大家整理了關(guān)于Python生成指定數(shù)量的優(yōu)惠碼的實例內(nèi)容以及相關(guān)代碼,有需要的朋友們學(xué)習(xí)下。2019-06-06
python中JSON數(shù)據(jù)格式的詳細(xì)使用教程
這篇文章主要給大家介紹了關(guān)于python中JSON數(shù)據(jù)格式的詳細(xì)使用,JSON是一種用于存儲和交換數(shù)據(jù)的語法,JSON是文本,使用JavaScript對象表示法編寫,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02

