本文實(shí)例講述了python 協(xié)程中的迭代器,生成器原理及應(yīng)用。分享給大家供大家參考,具體如下:
迭代器:
迭代器是訪(fǎng)問(wèn)可迭代對(duì)象的工具
迭代器是指用iter(obj)函數(shù)返回的對(duì)象(實(shí)例)
迭代器是指用next(it)函數(shù)獲取可迭代對(duì)象的數(shù)據(jù)
迭代器函數(shù)(iter和next)
iter(iterable)從可迭代對(duì)象中返回一個(gè)迭代器,iterable必須是能提供一個(gè)迭代器的對(duì)象
next(iterator) 從迭代器iterator中獲取下一了記錄,如果無(wú)法獲取下一條記錄,則觸發(fā)stoptrerator異常
說(shuō)明:
1.迭代器只能往前取值,不會(huì)后退
2.用iter函數(shù)可以返回一個(gè)可迭代對(duì)象的迭代器
class Fabonacci(object): def __init__(self,all_num): self.all_num = all_num self.current_num = 0 self.a = 0 self.b = 1 def __iter__(self): return self def __next__(self): if self.current_num < self.all_num: ret = self.a self.a, self.b = self.b, self.a + self.b self.current_num += 1 return ret else: raise StopIterationfibo = Fabonacci(10)for num in fibo: print(num)
生成器(generator)
是構(gòu)造新的可迭代對(duì)象的一種簡(jiǎn)單方式。一般的函數(shù)return只會(huì)返回單個(gè)值,而生成器并不是直接將可迭代值直接放入內(nèi)存中,而是以延遲的方式返回一個(gè)值序列,即每返回一個(gè)值之后暫停,直到下一個(gè)值被請(qǐng)求時(shí)再繼續(xù),可有效節(jié)省內(nèi)存占用。
要構(gòu)建一個(gè)生成器,則需要用到關(guān)鍵字yield,yield的作用與函數(shù)的返回值return有些類(lèi)似,通過(guò)在函數(shù)中將return替換成yield就是把函數(shù)變成生成器,帶有
yield 的函數(shù)不再是普通函數(shù),python
解釋器會(huì)將函數(shù)對(duì)象視為生成器對(duì)象,并且該生成器返回的是yield表達(dá)式生成的可迭代值序列,可通過(guò)for循環(huán)等方法依次讀取生成器返回的可迭代值序列
生成器生成的可迭代值只可以被讀取一次,每一次迭代都是按生成器代碼流程遇見(jiàn)yield表達(dá)式就返回值并記錄位置后中止留待下一次迭代,下一次迭代時(shí)執(zhí)行代碼的起始位置是從上一次記錄位置開(kāi)始,直至整個(gè)生成器代碼運(yùn)行結(jié)束。
1)
def create_num(all_num): a, b = 0, 1 current_num = 0 while current_num < all_num: # print(a) yield a a, b = b, a+b current_num += 1obj = create_num(10)while True: try: ret = next(obj) print(ret) except Exception as ret: break
2)通過(guò)send啟動(dòng)生成器
send一般不會(huì)放到第一次啟動(dòng)生成器,如果非要這么做,那么傳遞None
錯(cuò)誤示范:
def create_num(all_num): a, b = 0, 1 current_num = 0 while current_num < all_num: ret = yield a print(">>>ret>>>", ret) a, b = b, a+b current_num += 1obj = create_num(10)ret = obj.send("hello") #第一個(gè)就調(diào)用send方法print(ret)ret = next(obj)print(ret)
新聞熱點(diǎn)
疑難解答
圖片精選