Python 中 yeild 的用法

来源:https://www.cnblogs.com/cxqiang/archive/2023/06/06/17461141.html
-Advertisement-
Play Games

基於java的養老院管理系統設計與實現;可適用於敬老院管理系統,老人管理系統,老人信息管理系統,java養老院信息系統,java敬老院信息管理系統; ...


本文包含以下四部分:

  1. yeild 介紹
  2. yeild 案例
  3. 簡單的例子對比yeild和常規函數
  4. 複雜的例子說明yeild 與普通函數的差異

1. yeild 介紹

yield 是 Python 的一個關鍵字,用於從一個函數中返回一個生成器(generator)。生成器是一種特殊類型的迭代器,它允許你延遲計算結果,這在處理大數據或者創建複雜數據結構時特別有用,因為你不需要一次性將所有的數據都存儲在記憶體中。

一個使用 yield 的函數會被稱為生成器函數。這種函數並不直接返回一個值,而是生成一系列的值。每次調用這個生成器函數,它會從上次離開的地方繼續執行,並且可以產生許多結果,而不是單個值。

2. yeild 案例

以下是一個簡單的使用 yield 的例子

點擊查看代碼
def simple_generator():
    yield 1
    yield 2
    yield 3

> 使用生成器
for num in simple_generator():
    print(num)

輸出:

點擊查看代碼
1
2
3

在上面的例子中,simple_generator 是一個生成器函數,它生成了三個值:1, 2, 和 3。在 for 迴圈中,每次迭代都會從生成器中獲取一個新的值。

可以想象,每當 yield 被調用時,函數會生成一個新的值,然後暫停執行。當下一個值被請求時(例如,在 for 迴圈中的下一次迭代),函數會從上次離開的地方恢復執行,再次運行到 yield 語句,然後再次暫停。

這就是 yield 的基本用法。它在處理大數據集或創建複雜的數據結構時特別有用,因為它允許你按需生成和處理數據,而不是一次性生成所有數據並一次性處理所有數據,這樣可以大大節省記憶體。

3. 簡單的例子對比yeild和常規函數

當然,讓我們通過一個簡單的例子來展示 yield 的用法,以及與常規函數返回一個完整列表的區別。

首先,讓我們創建一個常規的函數,該函數將返回一個列表,其中包含從0到n的所有數字:

點擊查看代碼
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)

此函數將創建一個包含所有數字的列表,然後返回這個列表。如果 n 非常大,那麼列表將占用大量記憶體。

現在,我們使用 yield 關鍵字改寫這個函數,使其成為一個生成器:

點擊查看代碼
def create_numbers(n):
    for i in range(n):
        yield i

nums = create_numbers(5)
for num in nums:
    print(num)

在這個版本的函數中,我們並沒有一次性創建一個完整的列表。相反,我們使用 yield 關鍵字,在每次迭代時生成下一個數字。這種方法對記憶體的利用更高效,因為我們並不需要在記憶體中一次性存儲所有的數字。無論 n 多大,這個生成器在任何時候都只會產生一個數字。

當你需要處理大量數據時,這種方式特別有用。它允許你創建一個不會因數據量太大而耗盡記憶體的數據流。這也是生成器與常規函數的主要區別。

4. 複雜的例子說明yeild 與普通函數的差異

下麵讓我們使用一個更複雜的例子來說明 yield 和普通函數之間的差異。

假設我們要生成一個斐波那契數列,其中每個數字都是前兩個數字的和。假設我們要生成前 N 個斐波那契數。

以下是使用普通函數生成斐波那契數列的方法:

點擊查看代碼
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]

這個函數會一次性生成所有的斐波那契數,並將它們存儲在一個列表中。這意味著所有的數都將同時存在於記憶體中。

現在,讓我們嘗試使用一個生成器來完成同樣的任務:

點擊查看代碼
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]

這個生成器會一次生成一個斐波那契數,每次你從生成器請求一個數時,它都會計算出新的數並返回。這意味著在任何時候,只有一個斐波那契數存在於記憶體中。

如果你要生成的斐波那契數非常多(例如,幾百萬個),那麼生成器版本的函數將大大節省記憶體。此外,如果你只需要迭代而不需要所有的斐波那契數,那麼使用生成器可以讓你的代碼更加高效。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 某日二師兄參加XXX科技公司的C++工程師開發崗位第7面: > 面試官:C++中,`static`和`const`的關鍵字有哪些用法? > > 二師兄:`satic`關鍵字主要用在以下三個方面:1.用在全局作用域,修飾的變數或者函數為靜態的,限制在本文件內使用。2.方法內修飾修飾靜態局部變數,在第一 ...
  • # 演算法 in Golang:Quicksort(快速排序) ## Quicksort(快速排序) - 快速排序 O(nlog2^n),比選擇排序要快 O(n²) - 在日常生活中經常使用 - 使用了 D & C 策略(分而治之) ## 使用 Quicksort 排序數組 - 不需要排序的數組(也就 ...
  • ### 前言 有多少小伙伴是被標題 ~~騙~~ 吸引進來的呢,我可不是標題黨,今天的文章呢確實跟”金錢“有關係。 但是我們說的不是過度追求金錢而掉入陷阱,而是要說一說在Java程式中,各種跟金錢運算有關的陷阱。 日常工作中我們經常會涉及到各種金額這樣**浮點數的運算**。 一旦涉及到金額的運算就必須 ...
  • 博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
  • # 地圖可視化 basemap安裝和使用 區域縮放與繪圖 綜合案例:美國人口分佈圖 # seaborn可視化 樣式與分佈圖 分類圖 # basemap地圖繪製 地圖繪製也是數據可視化的一部分,常用的地圖繪製庫為basemap工具包,其為matplotlib的子包。本章將講解如何利用whl文件在Pyt ...
  • # 演算法 in Golang:Recursion(遞歸) ## 遞歸演算法 ### 場景:在套娃中找到寶石 ### 可以這樣做 - while 沒找到: - if 當前項 is 寶石: - return 寶石 - else if 當前項 is 套娃: - 打開這個套娃 - if 當前項 is 寶石: ...
  • # JVM運行時數據區 ## 簡介 JVM運行時數據區包括:JVM棧(虛擬機棧),堆,方法區,本地方法棧,PC寄存器。大概的劃分就是棧和堆,以及一些其他的結構。重點在JVM棧,堆,方法區。JVM規範指出:方法區在邏輯上屬於堆,但是實際的具體的JVM中並不屬於堆的一部分。 在JVM棧中會發生GC和Er ...
  • 本文使用代碼片段的形式來解釋在 go 語言開發中經常遇到的小功能點,由於本人主要使用 java 開發,因此會與其作比較,希望對大家有所幫助。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...