yield的語法規則是:
在yield這裡暫停函數執行,並返回yield後面表達式的值(默認為None),直到被next()再次調用時,從上次暫停的yield代碼處繼續往下執行。當沒有可繼續next()時,拋出異常,該異常可被for循環處理。
def fib(n):
def fib(n): a, b = 0, 1 i = 0 while i < n: yield b a, b = b, a+b i += 1 if __name__ == '__main__': f = fib(10) for item in f: print(item)
python中,含有yield關鍵字的對象就是一個生成器,每次調用next方法時會執行到yield後面的語句,然後返回yield後面代碼塊的執行結果
def foo(): bar_a = yield 1 # bar_a是語句塊(yield 1)的返回值,默認為None bar_b = yield bar_a yield "最後一個值,再迭代就要報StopIteration了" f = foo() # 創建生成器,此時沒有執行foo()裡的任何語句 print(next(f)) # 從foo()裡進入,一直執行到(yield 1)處,此時變量bar_a還沒有創建 print(next(f)) # 先將語句塊(yield 1)的返回值賦值個bar_a,此時bar_a的值是None。 # 然後執行到語句塊(yield bar_a),bar_b也還沒有被創建 print(next(f) >>>1 >>>None >>>最後一個值,再迭代就要報StopIteration了
send()
def foo(): bar_a = yield 1 bar_b = yield bar_a yield "最後一個值,再迭代就要報StopIteration了" f = foo() print(f.send(None)) # 和next(f)的效果一模一樣 print(f.send("my lover")) # 覆蓋yield 1語句的返回值 print(next(f)) >>>1 >>>my lover >>>最後一個值,再迭代就要報StopIteration了
[sl_ivan ] Python生成器next方法和send方法區別詳解已經有252次圍觀