日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

【Python学习教程】推导式与生成器

發布時間:2025/3/20 python 8 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Python学习教程】推导式与生成器 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

當我們對一批可迭代的數據(如列表或字典)進行提取或處理,最后要得到一個新的列表或字典時,推導式是一種非常簡潔的表達方式。

列表推導式

比如,有一批數據

data = [{'name': '張三', 'gender': 'male', 'age': 12},{'name': '李四', 'gender': 'female', 'age': 10},{'name': '王五', 'gender': 'male', 'age': 20},{'name': '趙六', 'gender': 'male', 'age': 11},{'name': '周七', 'gender': 'female', 'age': 16},{'name': '孫八', 'gender': 'male', 'age': 13}, ]

我們想要把數據中的name都提取出來形成一個新的列表,一般的操作是這樣的。

names = [] # 定義一個空列表for item in data: # 遍歷數據name = item['name'] # 提取每行中的namenames.append(name) # 追加到列表中

如果用推導式的話,形式如下。

names = [item['name'] for item in data] # 遍歷data,提取每項中的name生成一個新列表

數據處理

在提取數據時,我們還可以對每一項數據進行,處理,假設我們需要每個名稱前加上’姓名: '這個字符串,可以這樣。

names = ['姓名: '+item['name'] for item in data]

'姓名: '+item[‘name’] 就是每一項的數據

數據篩選

同樣我們還可以對數據進行篩選,比如我們只要年齡大于12歲,后面可以使用if進行過濾

names = [item['name'] for item in data if item['age']>12]

多重循環

推導式還支持多重循環,比如

''' 學習中遇到問題沒人解答?小編創建了一個Python學習交流QQ群:531509025 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' for x in range(1,5)if x > 2for y in range(1,4)if y < 3x*y

使用推導式表示如下

[x*y for x in range(1,5) if x > 2 for y in range(1,4) if y < 3]

批量執行操作

由于推導式就是一種循環操作,我們也可以使用推導式來批量執行一些相似操作,比如:

def step1(driver):print('步驟1)def step2(driver):print('步驟2)def step3(driver):print('步驟3)

我們可以將函數名放到一個列表里,然后使用推導式循環執行

steps = [step1, step2, step3] # 函數名列表[step(driver) for step in steps] # 不需要變量接收,我們只需要它循環執行

字典推導式

當我們需要遍歷一批數據最后得到一個字典時,同樣可以使用字典推導式,如:

''' 學習中遇到問題沒人解答?小編創建了一個Python學習交流QQ群:531509025 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' data = [{'name': '張三', 'gender': 'male', 'age': 12},{'name': '李四', 'gender': 'female', 'age': 10},{'name': '王五', 'gender': 'male', 'age': 20},{'name': '趙六', 'gender': 'male', 'age': 11},{'name': '周七', 'gender': 'female', 'age': 16},{'name': '孫八', 'gender': 'male', 'age': 13}, ]

假設我們想得到一個{‘張三’: 12, ‘李四’: 10, …}這樣的一個字典,使用字典推導式方式如下:

persons = {item['name']: item['age'] for item in data}

字典推導式同樣支持if篩選等操作。

生成器

生成器實際上是一種包含初始數據和推導法則的對象,比如我們可以輕松的寫出1w以內所有的奇數,原因是因為我只需要記住從1開始每次加2即可。

生成器便是這樣。對應大量的數據或者CSV/Excel文件中的數據,生成器可以大量的節省內存,比如csv.Reader(f)就是一個生成器,只存了當前位置和讀取下一行數據的方法。

當你需要遍歷時,它再每次給你讀取一行數據給你。
如列表推導式的例子,

data = [{'name': '張三', 'gender': 'male', 'age': 12},{'name': '李四', 'gender': 'female', 'age': 10},{'name': '王五', 'gender': 'male', 'age': 20},{'name': '趙六', 'gender': 'male', 'age': 11},{'name': '周七', 'gender': 'female', 'age': 16},{'name': '孫八', 'gender': 'male', 'age': 13}, ] names = [item['name'] for item in data]

我們把列表的中括號改為小括號就得到一個生成器

names2 = (item['name'] for item in data)

注意:生成器和推導式不同,其中的循環不是立即執行的,只用你遍歷這個生成器時才會執行

''' 學習中遇到問題沒人解答?小編創建了一個Python學習交流QQ群:531509025 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' for name in names: # 遍歷列表推導式生成的新列表print(name)for name in names2: # 遍歷一個生成器print(name)

兩個打印結果是一樣的,生成器更節省內存,只有遍歷時才運行。

總結

以上是生活随笔為你收集整理的【Python学习教程】推导式与生成器的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。