真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

pythonyield和yieldfrom用法總結詳解

創(chuàng)新互聯建站服務項目包括杜集網站建設、杜集網站制作、杜集網頁制作以及杜集網絡營銷策劃等。多年來,我們專注于互聯網行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯網行業(yè)的解決方案,杜集網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到杜集省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!python yield和yield from用法總結yield 作用:

注:generator的next()方法在python 2中為next(),但在python 3中為 __next__()【next的前后各是兩個下劃線】

把一個函數變成一個generator,帶有yield的函數不再是一個普通函數。即:一個帶有 yield 的函數就是一個 generator,它和普通函數不同,生成一個 generator 看起來像函數調用,但不會執(zhí)行任何函數代碼,直到對其調用 next()(在 for 循環(huán)中會自動調用 next())才開始執(zhí)行。雖然執(zhí)行流程仍按函數的流程執(zhí)行,但每執(zhí)行到一個 yield 語句就會中斷,并返回一個迭代值,下次執(zhí)行時從 yield 的下一個語句繼續(xù)執(zhí)行。看起來就好像一個函數在正常執(zhí)行的過程中被 yield 中斷了數次,每次中斷都會通過 yield 返回當前的迭代值。

yield 的好處是顯而易見的,把一個函數改寫為一個 generator 就獲得了迭代能力,比起用類的實例保存狀態(tài)來計算下一個 next() 的值,不僅代碼簡潔,而且執(zhí)行流程異常清晰。

用print實現打印斐波拉切數列 ——基礎版
#!/usr/bin/env python
# -*- coding: utf-8 -*-def fab(max):
    n , a, b = 0, 0 , 1
    while n < max:
        print(b)
        a, b = b, a + b
        n = n + 1if __name__ == '__main__':
    fab(6)  # 1 1 2 3 5 8
用yield實現打印斐波拉切數列——升級版
#!/usr/bin/env python
# -*- coding: utf-8 -*-def fab(max):
    n , a, b = 0, 0 , 1
    while n < max:
        yield b
        a, b = b, a + b
        n = n + 1if __name__ == '__main__':
    for n in fab(6): # 1 1 2 3 5 8
        print(n)
如何判斷一個函數是否是一個特殊的generator函數
#!/usr/bin/env python
# -*- coding: utf-8 -*-from inspect import isgeneratorfunction

def fab(max):
    n , a, b = 0, 0 , 1
    while n < max:
        yield b
        a, b = b, a + b
        n = n + 1if __name__ == '__main__':
    f1 = fab(3)
    # True fab是一個generator function
    print(isgeneratorfunction(fab))

    # False fab(3)不是一個generator function
    # 而fab(3)是調用fab返回的一個generator    print(isgeneratorfunction(fab(3)))
用yield實現大文件讀取
#!/usr/bin/env python
# -*- coding: utf-8 -*-def read_file(fpath):
    BLOCK_SIZE = 100
    with open(fpath, "rb") as f:
        while True:
            block = f.read(BLOCK_SIZE)
            if block:
                yield block            else:
                returnif __name__ == '__main__':
    fpath = "/home/exercise-python3.7.1/vote/mysite/mysite/polls/test.txt"
    read_gen = read_file(fpath)

    print(read_gen.__next__())
    print(read_gen.__next__())
    print(read_gen.__next__())
    print(read_gen.__next__())

    # for循環(huán)會自動調用generatr的__next__()方法,故輸出效果同如上的4個print  【內容較短,4個print就將test.txt中的內容輸出完了】    for data in read_gen:
        print(data)
yield 和 yield from 用法對比使用yield拼接可迭代對象
#!/usr/bin/env python
# -*- coding: utf-8 -*-if __name__ == '__main__':
    astr = "ABC"
    alist = [1, 2, 3]
    adict = {"name": "wangbm", "age": 18}
    # generate
    agen = (i for i in range(4, 8))

    def gen(*args, **kw):
        for item in args:
            for i in item:
                yield i

    new_list = gen(astr, alist, adict, agen)
    print(list(new_list))
    # ['A', 'B', 'C', 1, 2, 3, 'name', 'age', 4, 5, 6, 7]
使用yield from拼接可迭代對象
#!/usr/bin/env python
# -*- coding: utf-8 -*-if __name__ == '__main__':
    astr = "ABC"
    alist = [1, 2, 3]
    adict = {"name": "wangbm", "age": 18}
    # generate
    agen = (i for i in range(4, 8))

    def gen(*args, **kw):
        for item in args:
            yield from item

    new_list = gen(astr, alist, adict, agen)
    print(list(new_list))
    # ['A', 'B', 'C', 1, 2, 3, 'name', 'age', 4, 5, 6, 7]

結論:
由上面兩種方式對比,可以看出,yield from后面加上可迭代對象,他可以把可迭代對象里的每個元素一個一個的yield出來,對比yield來說代碼更加簡潔,結構更加清晰。

相關學習推薦:python視頻教程


網頁題目:pythonyield和yieldfrom用法總結詳解
網站路徑:http://weahome.cn/article/cjscpd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部