亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Python > 正文

舉例詳解Python中yield生成器的用法

2020-01-04 17:59:10
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了舉例詳解Python中yield生成器的用法,包括其在多線程multiprocess下的使用示例,非常推薦!需要的朋友可以參考下

yield是生成的意思,但是在python中則是作為生成器理解,生成器的用處主要可以迭代,這樣簡化了很多運算模型(還不是很了解是如何簡化的)。

yield是一個表達式,是有返回值的.

當一個函數中含有yield時,它不再是一個普通的函數,而是一個生成器.當該函數被調用時不會自動執行,而是暫停,見第一個例子:

例1:

 

 
  1. >>> def mygenerator(): 
  2. ... print 'start...' 
  3. ... yield 5 
  4. ...  
  5. >>> mygenerator() //在此處調用,并沒有打印出start...說明存在yield的函數沒有被運行,即暫停 
  6. <generator object mygenerator at 0xb762502c> 
  7. >>> mygenerator().next() //調用next()即可讓函數運行. 
  8. start... 
  9. >>>  

如一個函數中出現多個yield則next()會停止在下一個yield前,見例2:

例2:

 

 
  1. >>> def mygenerator(): 
  2. ... print 'start...' 
  3. ... yield 5 
  4. ...  
  5. >>> mygenerator() //在此處調用,并沒有打印出start...說明存在yield的函數沒有被運行,即暫停 
  6. <generator object mygenerator at 0xb762502c> 
  7. >>> mygenerator().next() //調用next()即可讓函數運行. 
  8. start... 
  9. >>>  

為什么yield 5會輸出5,yield 23會輸出23?

我們猜測可能是因為yield是表達式,存在返回值.

那么這是否可以認為yield 5的返回值一定是5嗎?實際上并不是這樣,這個與send函數存在一定的關系,這個函數實質上與next()是相似的,區別是send是傳遞yield表達式的值進去,而next不能傳遞特定的值,只能傳遞None進去,因此可以認為g.next()和g.send(None)是相同的。見例3:

例3:

 

 
  1. >>> def fun(): 
  2. ... print 'start...' 
  3. ... m = yield 5 
  4. ... print m 
  5. ... print 'middle...' 
  6. ... d = yield 12 
  7. ... print d 
  8. ... print 'end...' 
  9. ...  
  10. >>> m = fun() //創建一個對象 
  11. >>> m.next() //會使函數執行到下一個yield前 
  12. start... 
  13. >>> m.send('message'//利用send()傳遞值 
  14. message //send()傳遞進來的  
  15. middle... 
  16. 12 
  17. >>> m.next() 
  18. None //可見next()返回值為空 
  19. end... 
  20. Traceback (most recent call last): 
  21. File "<stdin>", line 1, in <module> 
  22. StopIteration 

在multiprocess中的使用

python在處理數據的時候,memory-heavy 的數據往往會導致程序沒辦反運行或者運行期間服務器其他程序效率受到影響。這種情況往往會把數據集合變為通過genertor來遍歷。

但同時如我們所知,generoter看似只能被單進程消費,這樣效率很低。

generator 可以被pool.map消費。

看一下pool.py的源碼。

 

 
  1. for i, task in enumerate(taskseq): 
  2. ... 
  3. try
  4. put(task) 
  5. except IOError: 
  6. debug('could not put task on queue'
  7. break 

實際是先將generator全部消費掉放到queue中。然后通過map來并行。這樣是解決了使用map來并行。

但是依然沒有解決占用內存的問題。這里有兩步占用內存。

第一步是全部消費掉的generator。

第二步并行運算全部data。

解決第一個問題,通過部分消費generator來達到。

解決第二個問題,可以通過imap來達到.

示例代碼如下:

 

 
  1. import multiprocessing as mp 
  2. import itertools 
  3. import time 
  4.  
  5.  
  6. def g(): 
  7. for el in xrange(50): 
  8. print el 
  9. yield el 
  10.  
  11. import os 
  12.  
  13. def f(x): 
  14. time.sleep(1) 
  15. print str(os.getpid()) +" "+ str(x) 
  16. return x * x 
  17.  
  18. if __name__ == '__main__'
  19. pool = mp.Pool(processes=4) # start 4 worker processes 
  20. go = g() 
  21. result = [] 
  22. N = 11 
  23. while True: 
  24. g2 = pool.imap(f, itertools.islice(go, N)) 
  25. if g2: 
  26. for i in g2: 
  27. result.append(i) 
  28. time.sleep(1) 
  29. else
  30. break 
  31. print(result) 

ps: 使用注意事項。在produce數據的時候,盡量少做操作,應為即使是map也是單線程的來消費數據。所以盡量把操作放到map中作。這樣才能更好的利用多進程提高效率。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性受xxx| 亚洲人成77777在线观看网| 国产91精品网站| 国产精品综合不卡av| 国产精品流白浆视频| 久久免费在线观看| 成人国产精品色哟哟| 国产精品一区二区3区| 国产欧美日韩亚洲精品| 国产欧美一区二区三区四区| 久久影院中文字幕| 欧美中文字幕在线| 欧美日韩不卡合集视频| 欧美肥老太性生活视频| 亚洲天堂视频在线观看| 国产精品久久在线观看| 日本不卡高字幕在线2019| 国产丝袜一区二区三区| 成人黄在线观看| 一个人看的www久久| 亚洲美女动态图120秒| 欧美丰满片xxx777| 性欧美亚洲xxxx乳在线观看| 欧美刺激性大交免费视频| 91在线视频一区| 亚洲第一页自拍| 日韩成人高清在线| 亚洲福利视频久久| 91国产视频在线| 成人免费午夜电影| 2019国产精品自在线拍国产不卡| 国产亚洲人成网站在线观看| 国产成人精品av在线| 91免费人成网站在线观看18| 国产综合在线视频| 亚洲久久久久久久久久久| 91成人在线播放| 欧美日韩国产精品一区二区三区四区| 一区二区欧美亚洲| 亚洲老头老太hd| 97精品视频在线| 久久精品视频在线观看| 日韩av在线一区| 日韩精品欧美国产精品忘忧草| 成人在线视频网| 欧美日韩成人在线播放| 久久久人成影片一区二区三区观看| 一本色道久久88精品综合| 91在线免费视频| 亚洲成人黄色在线观看| 日韩精品在线观看视频| 国产欧美亚洲精品| 性欧美xxxx视频在线观看| 91久久综合亚洲鲁鲁五月天| 欧美丰满少妇xxxxx做受| 日韩欧美精品网站| 国产伦精品一区二区三区精品视频| 精品高清美女精品国产区| 国产精品欧美激情在线播放| 久久精品一区中文字幕| 欧美小视频在线| 国产精品久久久久久久久久99| 91精品久久久久久久久久久久久久| 国产一区二区三区在线免费观看| 国产999精品久久久影片官网| 国产成人精品a视频一区www| 亚洲少妇中文在线| y97精品国产97久久久久久| 精品国产精品自拍| 欧美重口另类videos人妖| 亚洲小视频在线观看| 岛国精品视频在线播放| 国产91精品青草社区| 久久国产精品影片| 91精品国产自产在线观看永久| 国产精品视频精品| 欧美精品国产精品日韩精品| 深夜福利日韩在线看| 亚洲免费视频网站| 色综合影院在线| 国产精品高清免费在线观看| 日韩免费高清在线观看| 欧美视频在线免费看| 精品久久久久久久久中文字幕| 91九色精品视频| 亚洲欧美日韩直播| 欧美在线不卡区| 国产精品久久久久久久久久久不卡| 精品福利免费观看| 欧美日韩国产色视频| 亚洲国产精品推荐| 欧美在线视频a| 日韩成人在线免费观看| 久久影视电视剧免费网站清宫辞电视| 亚洲精品免费在线视频| 国产亚洲欧美另类中文| 欧美寡妇偷汉性猛交| 2021国产精品视频| 亚洲v日韩v综合v精品v| 国内精品久久久久久| 日韩在线免费观看视频| 欧美疯狂性受xxxxx另类| 日韩中文字幕在线视频播放| 日韩电影免费观看在线观看| 国产精品久久色| 97视频在线观看成人| 日韩av一区二区在线观看| 91精品国产成人| 亚洲网站在线观看| 亚洲开心激情网| 中文字幕一区日韩电影| 久久av在线播放| 91精品国产成人www| 国产精品欧美激情| 成人福利视频在线观看| 美乳少妇欧美精品| 亚洲人成人99网站| 中文字幕一区二区精品| 91免费在线视频| 日韩男女性生活视频| 久热精品视频在线免费观看| 欧美男插女视频| 夜夜嗨av一区二区三区四区| 国产精品激情av在线播放| 国产伦精品免费视频| 亚洲性夜色噜噜噜7777| 91九色视频在线| 亚洲欧美激情在线视频| 欧美在线视频a| 久久精品国产99国产精品澳门| 日韩在线免费高清视频| 欧美日韩性视频在线| 国产精品91久久久久久| 北条麻妃一区二区三区中文字幕| 日本久久精品视频| 久久视频国产精品免费视频在线| 2025国产精品视频| 日韩电影免费观看在线观看| 2019中文在线观看| 国产精品扒开腿做爽爽爽视频| 欧美国产激情18| 欧美日韩亚洲国产一区| 亚洲女人天堂视频| 日韩在线视频网站| 亚洲第一男人天堂| 69久久夜色精品国产7777| 91成品人片a无限观看| 久久精品中文字幕电影| 色综合男人天堂| 亚洲电影免费观看高清完整版在线观看| 欧美日韩另类视频| 岛国av一区二区| 国产69久久精品成人| 欧美wwwxxxx| 中文字幕欧美日韩| 69久久夜色精品国产69乱青草| 日韩经典中文字幕在线观看| 日韩av三级在线观看| 国产91精品视频在线观看| 亚洲最大激情中文字幕| 国产精品亚洲片夜色在线| 亚洲aaaaaa| 一区二区欧美日韩视频| 日韩精品免费在线|