歡迎您光臨本站 註冊首頁

Python生成器next方法和send方法區別詳解

←手機掃碼閱讀     sl_ivan @ 2020-06-05 , reply:0

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__ == &#x27;__main__&#x27;:    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次圍觀

http://coctec.com/docs/python/shhow-post-237057.html