這篇文章主要講解了“Python生成器的用法”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Python生成器的用法”吧!
成都創(chuàng)新互聯(lián)從2013年開始,先為龍江等服務建站,龍江等地企業(yè),進行企業(yè)商務咨詢服務。為龍江企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務解決您的所有建站問題。在 Python 中,使用了 yield 的函數(shù)被稱為生成器(generator)。
跟普通函數(shù)不同的是,生成器是一個返回迭代器的函數(shù),只能用于迭代操作,更簡單點理解生成器就是一個迭代器。
在調(diào)用生成器運行的過程中,每次遇到 yield 時函數(shù)會暫停并保存當前所有的運行信息,返回yield的值。并在下一次執(zhí)行 next()方法時從當前位置繼續(xù)運行。
import sys def fibonacci(n): # 生成器函數(shù) - 斐波那契 a, b, counter = 0, 1, 0 while True: if (counter > n): return yield a a, b = b, a + b counter += 1 f = fibonacci(10) # f 是一個迭代器,由生成器返回生成 while True: try: print(next(f), end=" ") except StopIteration: sys.exit() 執(zhí)行以上程序,輸出結(jié)果如下: 0 1 1 2 3 5 8 13 21 34 55
python中的reduce內(nèi)建函數(shù)是一個二元操作函數(shù),他用來將一個數(shù)據(jù)集合(鏈表,元組等)中的所有數(shù)據(jù)進行下列操作:用傳給reduce中的函數(shù) func()(必須是一個二元操作函數(shù))先對集合中的第1,2個數(shù)據(jù)進行操作,得到的結(jié)果再與第三個數(shù)據(jù)用func()函數(shù)運算,最后得到一個結(jié)果。
如:
def myadd(x,y): return x+y sum=reduce(myadd,(1,2,3,4,5,6,7)) print sum #結(jié)果就是輸出1+2+3+4+5+6+7的結(jié)果即28 當然,也可以用lambda的方法,更為簡單: sum=reduce(lambda x,y:x+y,(1,2,3,4,5,6,7)) print sum
在python 3.0.0.0以后, reduce已經(jīng)不在built-in function里了, 要用它就得from functools import reduce.
感謝各位的閱讀,以上就是“Python生成器的用法”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對Python生成器的用法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!
文章標題:Python生成器的用法-創(chuàng)新互聯(lián)
本文鏈接:http://jinyejixie.com/article28/hghcp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設、面包屑導航、全網(wǎng)營銷推廣、網(wǎng)站設計、品牌網(wǎng)站建設、移動網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容