Python生成器generator和yield關(guān)鍵字的使用
Python生成器generator和yield關(guān)鍵字
生成器 generator 是一個返回迭代器的函數(shù),只能用于迭代操作,更簡單點理解生成器就是一個迭代器。
實現(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ù)的運行結(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
運行結(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
運行結(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-07python實現(xiàn)字典合并的五種方法(附示例代碼)
在Python中,有多種方法可以通過使用各種函數(shù)和構(gòu)造函數(shù)來合并字典,在本文中,我們將討論一些合并字典的方法,并通過代碼示例講解的非常詳細,具有一定的參考價值,需要的朋友可以參考下2024-04-04利用 PyCharm 實現(xiàn)本地代碼和遠端的實時同步功能
這篇文章主要介紹了利用 PyCharm 實現(xiàn)本地代碼和遠端的實時同步功能,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03詳解Python函數(shù)可變參數(shù)定義及其參數(shù)傳遞方式
這篇文章主要介紹了詳解Python函數(shù)可變參數(shù)定義及其參數(shù)傳遞方式的相關(guān)資料,這里提供實例代碼幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08Python生成指定數(shù)量的優(yōu)惠碼實操內(nèi)容
在本篇文章里小編給大家整理了關(guān)于Python生成指定數(shù)量的優(yōu)惠碼的實例內(nèi)容以及相關(guān)代碼,有需要的朋友們學(xué)習(xí)下。2019-06-06python中JSON數(shù)據(jù)格式的詳細使用教程
這篇文章主要給大家介紹了關(guān)于python中JSON數(shù)據(jù)格式的詳細使用,JSON是一種用于存儲和交換數(shù)據(jù)的語法,JSON是文本,使用JavaScript對象表示法編寫,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-02-02