Python?中?yeild?的用法詳解
1. yeild 介紹
yield 是 Python 的一個關(guān)鍵字,用于從一個函數(shù)中返回一個生成器(generator)。生成器是一種特殊類型的迭代器,它允許你延遲計算結(jié)果,這在處理大數(shù)據(jù)或者創(chuàng)建復雜數(shù)據(jù)結(jié)構(gòu)時特別有用,因為你不需要一次性將所有的數(shù)據(jù)都存儲在內(nèi)存中。
一個使用 yield 的函數(shù)會被稱為生成器函數(shù)。這種函數(shù)并不直接返回一個值,而是生成一系列的值。每次調(diào)用這個生成器函數(shù),它會從上次離開的地方繼續(xù)執(zhí)行,并且可以產(chǎn)生許多結(jié)果,而不是單個值。
2. yeild 案例
以下是一個簡單的使用 yield 的例子
def simple_generator(): yield 1 yield 2 yield 3 > 使用生成器 for num in simple_generator(): print(num)
輸出:
1 2 3
在上面的例子中,simple_generator 是一個生成器函數(shù),它生成了三個值:1, 2, 和 3。在 for 循環(huán)中,每次迭代都會從生成器中獲取一個新的值。
可以想象,每當 yield 被調(diào)用時,函數(shù)會生成一個新的值,然后暫停執(zhí)行。當下一個值被請求時(例如,在 for 循環(huán)中的下一次迭代),函數(shù)會從上次離開的地方恢復執(zhí)行,再次運行到 yield 語句,然后再次暫停。
這就是 yield 的基本用法。它在處理大數(shù)據(jù)集或創(chuàng)建復雜的數(shù)據(jù)結(jié)構(gòu)時特別有用,因為它允許你按需生成和處理數(shù)據(jù),而不是一次性生成所有數(shù)據(jù)并一次性處理所有數(shù)據(jù),這樣可以大大節(jié)省內(nèi)存。
3. 簡單的例子對比yeild和常規(guī)函數(shù)
當然,讓我們通過一個簡單的例子來展示 yield 的用法,以及與常規(guī)函數(shù)返回一個完整列表的區(qū)別。
首先,讓我們創(chuàng)建一個常規(guī)的函數(shù),該函數(shù)將返回一個列表,其中包含從0到n的所有數(shù)字:
def create_numbers(n): num_list = [] for i in range(n): num_list.append(i) return num_list nums = create_numbers(5) for num in nums: print(num)
此函數(shù)將創(chuàng)建一個包含所有數(shù)字的列表,然后返回這個列表。如果 n 非常大,那么列表將占用大量內(nèi)存。
現(xiàn)在,我們使用 yield 關(guān)鍵字改寫這個函數(shù),使其成為一個生成器:
def create_numbers(n): for i in range(n): yield i nums = create_numbers(5) for num in nums: print(num)
在這個版本的函數(shù)中,我們并沒有一次性創(chuàng)建一個完整的列表。相反,我們使用 yield 關(guān)鍵字,在每次迭代時生成下一個數(shù)字。這種方法對內(nèi)存的利用更高效,因為我們并不需要在內(nèi)存中一次性存儲所有的數(shù)字。無論 n 多大,這個生成器在任何時候都只會產(chǎn)生一個數(shù)字。
當你需要處理大量數(shù)據(jù)時,這種方式特別有用。它允許你創(chuàng)建一個不會因數(shù)據(jù)量太大而耗盡內(nèi)存的數(shù)據(jù)流。這也是生成器與常規(guī)函數(shù)的主要區(qū)別。
4. 復雜的例子說明yeild 與普通函數(shù)的差異
下面讓我們使用一個更復雜的例子來說明 yield 和普通函數(shù)之間的差異。
假設我們要生成一個斐波那契數(shù)列,其中每個數(shù)字都是前兩個數(shù)字的和。假設我們要生成前 N 個斐波那契數(shù)。
以下是使用普通函數(shù)生成斐波那契數(shù)列的方法:
def fibonacci(n): nums = [] a, b = 0, 1 while len(nums) < n: nums.append(b) a, b = b, a + b return nums print(fibonacci(10)) # 輸出: [1, 1, 2, 3, 5, 8, 13, 21, 34, 55]
這個函數(shù)會一次性生成所有的斐波那契數(shù),并將它們存儲在一個列表中。這意味著所有的數(shù)都將同時存在于內(nèi)存中。
現(xiàn)在,讓我們嘗試使用一個生成器來完成同樣的任務:
def fibonacci(n): yield 1 if n > 1: a, b = 1, 1 while n > 1: a, b = b, a + b yield a n -= 1 print(list(fibonacci(10))) # 輸出: [1, 1, 2, 3, 5, 8, 13, 21, 34, 55]
這個生成器會一次生成一個斐波那契數(shù),每次你從生成器請求一個數(shù)時,它都會計算出新的數(shù)并返回。這意味著在任何時候,只有一個斐波那契數(shù)存在于內(nèi)存中。
如果你要生成的斐波那契數(shù)非常多(例如,幾百萬個),那么生成器版本的函數(shù)將大大節(jié)省內(nèi)存。此外,如果你只需要迭代而不需要所有的斐波那契數(shù),那么使用生成器可以讓你的代碼更加高效。
yield 是 Python 中非常重要的關(guān)鍵字,可以將函數(shù)變成迭代器,實現(xiàn)惰性計算,節(jié)省內(nèi)存空間。yield 的基本用法是在生成器函數(shù)中使用,通過 yield 關(guān)鍵字返回一個值,并暫停函數(shù)的執(zhí)行,等待下一次調(diào)用。yield 的實現(xiàn)原理是通過生成器對象實現(xiàn)的,每次調(diào)用生成器對象的 next() 方法時,會執(zhí)行生成器函數(shù)中的代碼,直到遇到 yield 關(guān)鍵字。與 yield 相關(guān)的注意事項包括:生成器函數(shù)只能用于迭代器中,yield 只能在生成器函數(shù)中使用,yield 可以返回多個值,但只能接收一個值。常見問題包括:如何在生成器函數(shù)中使用 return 關(guān)鍵字,如何在生成器函數(shù)中使用異常處理,如何在生成器函數(shù)中使用多個 yield 關(guān)鍵字。
到此這篇關(guān)于Python 中 yeild 的用法詳解的文章就介紹到這了,更多相關(guān)Python 中 yeild 的用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python聊天室?guī)Ы缑鎸崿F(xiàn)的示例代碼(tkinter,Mysql,Treading,socket)
這篇文章主要介紹了Python聊天室?guī)Ы缑鎸崿F(xiàn)的示例代碼(tkinter,Mysql,Treading,socket),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04Python使用FastParquet庫處理Parquet文件的方法
在大數(shù)據(jù)時代,數(shù)據(jù)存儲和處理的效率至關(guān)重要,Parquet作為一種列式存儲格式,因其高效的壓縮和編碼方案,成為大數(shù)據(jù)處理中的熱門選擇,本文將深入探討FastParquet庫的使用,幫助讀者掌握如何利用這一工具高效處理Parquet文件,需要的朋友可以參考下2025-02-02anaconda安裝pytorch1.7.1和torchvision0.8.2的方法(親測可用)
這篇文章主要介紹了anaconda安裝pytorch1.7.1和torchvision0.8.2的方法(親測可用),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02Django rest framework實現(xiàn)分頁的示例
這篇文章主要介紹了Django rest framework實現(xiàn)分頁的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05