python 生成器 generator

来源:http://www.cnblogs.com/gundan/archive/2017/12/16/8047495.html
-Advertisement-
Play Games

一、生成器定義 通過列表生成表達式,我們可以直接創建一個列表。但是,受到記憶體限制,列表容量肯定是有限的。所以,如果列表元素可以按照某種演算法推算出來,那我們是否可以在迴圈的過程中不斷推算出後續的元素呢?這樣就不必創建完整的list,從而節省大量的空間。在Python中,這種一邊迴圈一邊計算的機制,稱為 ...


一、生成器定義

通過列表生成表達式,我們可以直接創建一個列表。但是,受到記憶體限制,列表容量肯定是有限的。所以,如果列表元素可以按照某種演算法推算出來,那我們是否可以在迴圈的過程中不斷推算出後續的元素呢?這樣就不必創建完整的list,從而節省大量的空間。在Python中,這種一邊迴圈一邊計算的機制,稱為生成器:generator。

1 >>> l = [x * x for x in range(10)]
2 >>> l
3 [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
4 >>> g = (x * x for x in range(10))
5 >>> g
6 <generator object <genexpr> at 0x1013e0780>

二、表達式生成器

創建l和g的區別僅在於最外層的[]和(),l是一個list,而g是一個generator。可以直接列印出l的每一個元素,列印出g的每一個元素需要使用next()函數。

 1 >>> g = (x * x for x in range(10))
 2 >>> g
 3 <generator object <genexpr> at 0x1013e0780>
 4 >>> next(g)
 5 0
 6 >>> next(g)
 7 1
 8 >>> next(g)
 9 4
10 >>> next(g)
11 9
12 >>> next(g)
13 16
14 >>> next(g)
15 25
16 >>> next(g)
17 36
18 >>> next(g)
19 49
20 >>> next(g)
21 64
22 >>> next(g)
23 81
24 >>> next(g)
25 Traceback (most recent call last):
26   File "<stdin>", line 1, in <module>
27 StopIteration

generator保存的是演算法,每次調用next(g),就計算出g的下一個元素的值,直到計算到最後一個元素,沒有更多的元素時,拋出StopIteration的錯誤。

 1 >>> g = (x * x for x in range(10))
 2 >>> for n in g:
 3 ...     print(n)
 4 ... 
 5 0
 6 1
 7 4
 8 9
 9 16
10 25
11 36
12 49
13 64
14 81

首先generator是可迭代對象,所以可以使用for in迴圈遍歷。該遍歷的本質是for in迴圈內部調用next()函數獲取每一個元素,並且捕獲StopIteration異常,結束遍歷。

三、函數生成器

斐波拉契數列用列表生成式寫不出來,但是,用函數把它列印出來卻很容易。

 1 >>> def fib(max):
 2 ...     n, a, b = 0, 0, 1
 3 ...     while n < max:
 4 ...         yield b
 5 ...         a, b = b, a + b
 6 ...         n += 1
 7 ...     raise StopIteration('done')
 8 ... 
 9 >>> fib(6)
10 <generator object fib at 0x1013e0780>
11 >>> for i in fib(6):
12 ...     print(i)
13 ... 
14 1
15 1
16 2
17 3
18 5
19 8
20 >>> g = fib(6)
21 >>> while True:
22 ...     try:
23 ...         next(g)
24 ...     except StopIteration as e:
25 ...         print(e.value)
26 ...         break
27 ... 
28 1
29 1
30 2
31 3
32 5
33 8
34 done

 


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

-Advertisement-
Play Games
更多相關文章
  • 定義: 為子系統中的一組介面提供一個一致的界面,Facade模式定義了一個高層介面,這個介面使得這一子系統更加容易使用。 角色: 1,外觀(Facade)角色 :客戶端可以調用這個角色的方法。此角色知曉相關子系統的功能和責任。在正常情況下,本角色會將所有從客戶端發來的請求委派到相應的子系統去。 2, ...
  • 一、map()函數 map()函數接收兩個參數,一個是函數,一個是Iterable,map將傳入的函數依次作用到序列的每個元素,並把結果作為新的Iterator返回。 二、reduce()函數 reduce把一個函數作用在一個序列[x1, x2, x3, ...]上,這個函數必須接收兩個參數,red ...
  • 一、2個概念: 1、變數可以指向函數本身 2、函數名也是變數 二、高階函數 一個函數可以接收另一個函數作為參數,這種函數就稱之為高階函數。 ...
  • 要求: 1.完成常識中的ATM存取款機功能 2.把ATM機故障考慮進去 3.不能直接輸入賬戶名和卡號等等信息,模擬出插銀行卡讓ATM機自動讀取卡信息 4.密碼驗證超過三次錯誤即鎖定賬戶 5.操作類型有:存款,取款,查詢,轉賬,列印憑條,退卡,一共六個選項,跟用戶輸入做出不同的反饋 6.當用戶正常進入 ...
  • 概述      java中的參數傳遞問題可以根據參數的類型大致可以分為三類:傳遞基本類型,傳遞String類型,傳遞引用類型,至於最終是否可以歸納為值傳遞和引用傳遞,根據每個人的理解不同,答案不同,此處不做強調。 傳遞基本類型 結果 :Before ...
  • 參考大佬博文:blog.csdn.net/jia20003/article/details/7724530 lps-683.iteye.com/blog/2254368 openCV里有兩個函數(比較常用)處理霍夫變換直線檢測,有什麼區別呢。 CvHoughLine:是用於標準的霍夫變換方法 CvH ...
  • 作為一名軟體開發者,要追求的,應該是不斷地提升自己分析問題把握事物關鍵點,實事求是地給出切實可行且能“一劍封喉”的優雅解決方案的能力,再提升一點境界,就是要不斷提升自己創新的能力(即創造新東西、提出新思路、解決新問題的能力)。 我個人認為,花費大量的時間去"精通"某種語言、某個平臺和某些工具,其實是 ...
  • 一、可迭代對象定義 可以直接作用於for迴圈的數據類型有以下幾種: 一類是集合數據類型,如list、tuple、dict、set、str、bytes、bytearray等; 一類是generator,包括表達式生成器和帶yield的函數生成器。 這些可以直接作用於for迴圈的對象統稱為可迭代對象:I ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...