Python 3.3 中“yield from”的力量
Python 3.3 引入了“yield from”語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法,為程式設計帶來了革命性語法的方法與生成器和協程。雖然與常規生成器類似,yield from 在呼叫者和子生成器之間建立了直接連接,允許無縫雙向通訊。
1.從生成器讀取資料
最簡單的用例是從生成器讀取資料。透過使用yield from,我們可以使用類似於常規循環的簡化語法從生成器接收值。
例如,考慮一個模擬讀取資料的產生器:
<code class="python">def reader(): for i in range(4): yield '<< %s' % i
使用從yield 中,我們可以如下迭代資料:
<code class="python">def reader_wrapper(g): yield from g wrap = reader_wrapper(reader()) for i in wrap: print(i)
2.將資料傳送到協程
將資料傳送到協程時產生閃爍。使用yield from,傳送到包裝器的資料會透明地轉送到協程。
考慮一個將資料寫入特定目的地的協程:
<code class="python">def writer(): while True: w = (yield) print('>> ', w)</code>
使用yield將資料傳送到此編寫器來自:
<code class="python">def writer_wrapper(coro): coro.send(None) while True: try: x = (yield) coro.send(x) except StopIteration: pass w = writer() wrap = writer_wrapper(w) wrap.send(None) for i in range(4): wrap.send(i)</code>
3.異常處理
yield from 無縫處理異常。子生成器中引發的異常將傳播到呼叫者。此外,發送到包裝器的異常可以被丟到子產生器。
例如,在我們的編寫器協程中:
<code class="python">def writer(): while True: try: w = (yield) except SpamException: print('***') else: print('>> ', w)</code>
使用yield from,我們可以如下處理異常:
<code class="python">def writer_wrapper(coro): yield from coro</code>
4。雙向通訊的力量
yield from 的關鍵面向是它建立的雙向連線。它不僅可以向協程發送數據,還可以傳播異常並傳回子產生器的最終值。
結論
yield from 是一個強大的工具徹底改變了 Python 中的生成器和協程。它簡化了雙向通信,無縫處理異常,並允許優雅的解決方案。它的用例遠遠超出了所討論的範例,使其成為 Python 中許多高階程式設計任務的重要組成部分。
以上是釋放雙向通訊的力量:「yield from」為 Python 3.3 帶來了什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!