欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python列表推導(dǎo)式詳情

 更新時(shí)間:2021年11月01日 15:44:20   作者:一碗周  
這篇文章主要介紹了Python列表推導(dǎo)式,列表生成式即List Comprehensions,是Python內(nèi)置的非常簡(jiǎn)單卻強(qiáng)大的可以用來(lái)創(chuàng)建list的生成式,下面來(lái)看看詳細(xì)內(nèi)容吧

1、列表生成式

列表生成式即List Comprehensions,是Python內(nèi)置的非常簡(jiǎn)單卻強(qiáng)大的可以用來(lái)創(chuàng)建list的生成式。

語(yǔ)法結(jié)構(gòu)如下:

# 普通的生成式
[表達(dá)式 for 變量 in 舊列表]
# 加條件的生成式
[表達(dá)式 for 變量 in 舊列表 if 條件]
# if...else條件的生成式
[表達(dá)式 if 條件1 else 條件2for 變量 in 舊列表]

1.1 案例

過(guò)濾掉名詞字母不足4的名字,示例代碼如下:

names = ["Tom", "Lily", "Jack", "Steven", "Bod"]
# 在不是用列表生成式的過(guò)程
news_names = []
for name in names:
    if len(name) > 3:
        news_names.append(name)
print(news_names)  # ['Lily', 'Jack', 'Steven']
# 使用列表生成式
new_names = [name for name in names if len(name) > 3]
print(new_names)  # ['Lily', 'Jack', 'Steven']

顯而易見(jiàn),使用列表生成式可以節(jié)省很多行代碼

將1-100的整數(shù)可以被3和5整除的數(shù)字,組成一個(gè)新的列表.示例代碼,示例代碼如下所示:

# 將1-100的整數(shù)可以被3和5整除的數(shù)字,組成一個(gè)新的列表
# 舊方法
number_list = []
for i in range(101):
    if i % 3 == 0 and i % 5 == 0:
        number_list.append(i)
print(number_list)  # [0, 15, 30, 45, 60, 75, 90]

# 列表生成式
new_num_list = [i for i in range(101) if i % 3 == 0 and i % 5 == 0]
print(new_num_list)  # [0, 15, 30, 45, 60, 75, 90]

將0到10的奇數(shù)和0到5的偶數(shù)組成一個(gè)不重復(fù)的列表,示例代碼如下所示:

# 將0到10的奇數(shù)和0到5的偶數(shù)組成一個(gè)不重復(fù)的列表
# 舊方法
news_number_list = []
for x in range(10):
    if x % 2 != 0:
        for y in range(5):
            if y % 2 == 0:
                news_number_list.append([x, y])
print(news_number_list)
# [[1, 0], [1, 2], [1, 4], [3, 0], [3, 2], [3, 4], [5, 0], [5, 2], [5, 4], [7, 0], [7, 2], [7, 4], [9, 0], [9, 2],[9, 4]]

# 新方法
news_num_list = [[x, y]
                 for x in range(10) if x % 2 != 0 for y in range(6) if y % 2 == 0]
print(news_num_list)
# [[1, 0], [1, 2], [1, 4], [3, 0], [3, 2], [3, 4], [5, 0], [5, 2], [5, 4], [7, 0], [7, 2], [7, 4], [9, 0], [9, 2],[9, 4]]

同樣支持多個(gè)for語(yǔ)句,如果使用原來(lái)的那種方法的話(huà)層級(jí)結(jié)構(gòu)太深了,使用生成式一行解決

將列表中的數(shù)字大于8000的加200 小于等于8000的加500,示例代碼如下:

# 將列表中的數(shù)字大于8000的加200 小于等于8000的加500
number = [5000, 10000, 4500, 80000, 12000]

# 舊方法
for i in number:
    if i > 8000:
        i += 200
    else:
        i += 500
print(number)  # [5000, 10000, 4500, 80000, 12000]

# 新方法
new_number = [i + 200 if i > 8000 else i + 500 for i in number]
print(new_number)  # [5000, 10000, 4500, 80000, 12000]

2、集合生成式

語(yǔ)法結(jié)構(gòu)如下所示:

# 普通的生成式
{表達(dá)式 for 變量 in 舊列表}
# 加條件的生成式
{表達(dá)式 for 變量 in 舊列表 if 條件}
# if...else條件的生成式
{表達(dá)式 if 條件1 else 條件2for 變量 in 舊列表}

語(yǔ)法結(jié)構(gòu)與列表生成式基本相同,但是因?yàn)榧喜辉试S有重復(fù),所有得出的結(jié)果自動(dòng)去重

3、字典生成式

字典生成式與集合生成式和列表生成式的語(yǔ)法結(jié)構(gòu)一致,唯一不同的是字典是以鍵值對(duì)的形式存放信息的,如下例子中我們將dict中的鍵值互換,

示例代碼如下:

# 將字典的鍵值對(duì)互換
dict1 = {"a": "A", "b": "B", "c": "C"}
# 就方法
new_dict1 = {}
for key, value in dict1.items():  # 返回一個(gè)存放鍵值對(duì)的元組
    new_dict1[value] = key
print(new_dict1)  # {'A': 'a', 'B': 'b', 'C': 'c'}

# 新方法
news_dict1 = {value: key for key, value in dict1.items()}
print(news_dict1)  # {'A': 'a', 'B': 'b', 'C': 'c'}


item方法:返回可遍歷的(鍵, 值) 元組數(shù)組。

到此這篇關(guān)于Python列表推導(dǎo)式詳情的文章就介紹到這了,更多相關(guān)Python列表推導(dǎo)式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python使用pdfminer解析pdf文件的方法示例

    python使用pdfminer解析pdf文件的方法示例

    這篇文章主要介紹了python使用pdfminer解析pdf文件的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • python 遞歸調(diào)用返回None的問(wèn)題及解決方法

    python 遞歸調(diào)用返回None的問(wèn)題及解決方法

    這篇文章主要介紹了python 遞歸調(diào)用返回None的問(wèn)題,本文通過(guò)實(shí)例代碼給大家記錄了解決方案,代碼簡(jiǎn)單易懂,非常不錯(cuò)對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Python如何實(shí)現(xiàn)xml解析并輸出到Excel上

    Python如何實(shí)現(xiàn)xml解析并輸出到Excel上

    本文介紹了如何使用Python的ElementTree模塊解析XML文件,并將解析后的數(shù)據(jù)寫(xiě)入Excel文件,通過(guò)編寫(xiě)XML文件、解析XML、編寫(xiě)將數(shù)據(jù)寫(xiě)入Excel的函數(shù),最終實(shí)現(xiàn)XML數(shù)據(jù)到Excel的轉(zhuǎn)換
    2025-02-02
  • pytorch 自定義參數(shù)不更新方式

    pytorch 自定義參數(shù)不更新方式

    今天小編就為大家分享一篇pytorch 自定義參數(shù)不更新方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • Python 實(shí)現(xiàn)進(jìn)度條的六種方式

    Python 實(shí)現(xiàn)進(jìn)度條的六種方式

    這篇文章主要介紹了Python 實(shí)現(xiàn)進(jìn)度條的六種方式,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2021-01-01
  • 使用Python3中的gettext模塊翻譯Python源碼以支持多語(yǔ)言

    使用Python3中的gettext模塊翻譯Python源碼以支持多語(yǔ)言

    這篇文章主要介紹了使用Python3中的gettext模塊翻譯Python源碼以支持多語(yǔ)言,其中翻譯Python源碼只是作為示例以展示gettext的功能和用法,需要的朋友可以參考下
    2015-03-03
  • Python中的線(xiàn)程同步的常用方法總結(jié)

    Python中的線(xiàn)程同步的常用方法總結(jié)

    在Python多線(xiàn)程編程中,我們常常需要處理多個(gè)線(xiàn)程同時(shí)訪(fǎng)問(wèn)共享數(shù)據(jù)的情況,為了防止數(shù)據(jù)在多線(xiàn)程之間出現(xiàn)沖突,我們需要對(duì)線(xiàn)程進(jìn)行同步。本文將詳細(xì)介紹Python中的線(xiàn)程同步的幾種常用方法,需要的朋友可以參考下
    2023-06-06
  • Python中matplotlib如何改變畫(huà)圖的字體

    Python中matplotlib如何改變畫(huà)圖的字體

    這篇文章主要介紹了Python中matplotlib如何改變畫(huà)圖的字體,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • 一文帶你輕松搞定Python正則匹配

    一文帶你輕松搞定Python正則匹配

    在python?中,正則匹配用到的還是挺多的,下面這篇文章主要給大家介紹了關(guān)于Python正則匹配的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-08-08
  • 淺談解除裝飾器作用(python3新增)

    淺談解除裝飾器作用(python3新增)

    今天小編就為大家分享一篇淺談解除裝飾器作用(python3新增),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10

最新評(píng)論