0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

10個(gè)Python Itertools,讓你的代碼如虎添翼

jf_ZqFkd6Up ? 來(lái)源:Linux迷 ? 2023-05-25 09:45 ? 次閱讀

Python的美麗在于它的簡(jiǎn)潔性。

不僅因?yàn)镻ython的語(yǔ)法優(yōu)雅,還因?yàn)樗性S多設(shè)計(jì)良好的內(nèi)置模塊,能夠高效地實(shí)現(xiàn)常見(jiàn)功能。

itertools模塊就是一個(gè)很好的例子,它為我們提供了許多強(qiáng)大的工具,可以在更短的代碼中操作Python的可迭代對(duì)象。

用更少的代碼實(shí)現(xiàn)更多的功能,這就是你可以從itertools模塊中獲得的好處。讓我們從本文中了解一下。

1、itertools.product(): 避免嵌套循環(huán)的巧妙方法

當(dāng)程序變得越來(lái)越復(fù)雜時(shí),你可能需要編寫(xiě)嵌套循環(huán)。同時(shí),你的Python代碼將變得丑陋和難以閱讀:


list_a = [1, 2020, 70]
list_b = [2, 4, 7, 2000]
list_c = [3, 70, 7]


for a in list_a:
    for b in list_b:
        for c in list_c:
            if a + b + c == 2077:
                print(a, b, c)
# 70 2000 7
c654f4be-fa29-11ed-90ce-dac502259ad0.png

如何使上述代碼再次具有 Python 風(fēng)格?

那 itertools.product() 函數(shù)就是你的朋友:

from itertools import product


list_a = [1, 2020, 70]
list_b = [2, 4, 7, 2000]
list_c = [3, 70, 7]


for a, b, c in product(list_a, list_b, list_c):
    if a + b + c == 2077:
        print(a, b, c)
# 70 2000 7


如上所示,它返回輸入可迭代對(duì)象的笛卡爾積,幫助我們將三個(gè)嵌套的for循環(huán)合并為一個(gè)。

2、itertools.compress(): 過(guò)濾數(shù)據(jù)的便捷方式

我們可以通過(guò)一個(gè)或多個(gè)循環(huán)來(lái)篩選列表中的項(xiàng)。

但有時(shí)候,我們可能不需要編寫(xiě)任何循環(huán)。因?yàn)橛幸粋€(gè)名為itertools.compress()的函數(shù)。

itertools.compress()函數(shù)返回一個(gè)迭代器,根據(jù)相應(yīng)的布爾掩碼對(duì)可迭代對(duì)象進(jìn)行過(guò)濾。

例如,以下代碼使用itertools.compress()函數(shù)選擇出真正的領(lǐng)導(dǎo)者:

import itertools
leaders = ['Yang', 'Elon', 'Tim', 'Tom', 'Mark']
selector = [1, 1, 0, 0, 0]
print(list(itertools.compress(leaders, selector)))
# ['Yang', 'Elon']
c6616492-fa29-11ed-90ce-dac502259ad0.png


第二個(gè)參數(shù)selector作為掩碼起作用,我們也可以這樣定義它:

selector = [True, True, False, False, False]

3、itertools.groupby(): 對(duì)可迭代對(duì)象進(jìn)行分組

itertools.groupby()函數(shù)是一種方便的方式,用于將可迭代對(duì)象中相鄰的重復(fù)項(xiàng)進(jìn)行分組。

例如,我們可以將一個(gè)長(zhǎng)字符串進(jìn)行分組,如下所示:


from itertools import groupby


for key, group in groupby('LinnuxmiMi'):
    print(key, list(group))
c6681238-fa29-11ed-90ce-dac502259ad0.png

此外,我們可以利用它的第二個(gè)參數(shù)告訴groupby()函數(shù)如何確定兩個(gè)項(xiàng)是否相同:

from itertools import groupby


for key, group in groupby('LinnuxmiMi', lambda x: x.upper()):
    print(key, list(group))



4、itertools.combinations(): 從可迭代對(duì)象中獲取給定長(zhǎng)度的所有組合

對(duì)于初學(xué)者來(lái)說(shuō),編寫(xiě)一個(gè)無(wú) bug 的函數(shù)來(lái)獲取列表的所有可能組合可能需要一些時(shí)間。

事實(shí)上,如果她了解 itertools.combinations() 函數(shù),她可以很容易地實(shí)現(xiàn):


import itertools


author = ['L', 'i', 'n', 'u', 'x']


result = itertools.combinations(author, 2)


for a in result:
    print(a)
c66e35fa-fa29-11ed-90ce-dac502259ad0.png

如上所示,itertools.combinations()函數(shù)有兩個(gè)參數(shù),一個(gè)是原始可迭代對(duì)象,另一個(gè)是函數(shù)生成的子序列的長(zhǎng)度。

5、itertools.permutations(): 從可迭代對(duì)象中獲取給定長(zhǎng)度的所有排列

既然有一個(gè)函數(shù)可以獲取所有組合,當(dāng)然也有另一個(gè)名為itertools.permutations的函數(shù)來(lái)獲取所有可能的排列:


import itertools


author = ['Y', 'a', 'n', 'g']


result = itertools.permutations(author, 2)


for x in result:
    print(x)


# ('Y', 'a')
# ('Y', 'n')
# ('Y', 'g')
# ('a', 'Y')
# ('a', 'n')
# ('a', 'g')
# ('n', 'Y')
# ('n', 'a')
# ('n', 'g')
# ('g', 'Y')
# ('g', 'a')
# ('g', 'n')


如上所示,itertools.permutations()函數(shù)的用法與itertools.combinations()類似。唯一的區(qū)別在于它們的結(jié)果。

6、itertools.accumulate(): 從可迭代對(duì)象生成累積的項(xiàng)

基于可迭代對(duì)象獲取一系列累積值是一種常見(jiàn)需求。借助itertools.accumulate()函數(shù)的幫助,我們無(wú)需編寫(xiě)任何循環(huán)即可實(shí)現(xiàn)。


import itertools
import operator


nums = [1, 2, 3, 4, 5]
print(list(itertools.accumulate(nums, operator.mul)))
# [1, 2, 6, 24, 120]
如果我們不想使用operator.mul,上述程序可以改寫(xiě)如下:

import itertools


nums = [1, 2, 3, 4, 5]
print(list(itertools.accumulate(nums, lambda a, b: a * b)))
# [1, 2, 6, 24, 120]

7、itertools.repeat(), itertools.cycle(), itertools.count(): 生成無(wú)限迭代對(duì)象

在某些情況下,我們需要獲得無(wú)限迭代。有 3 個(gè)有用的功能:

itertools.repeat():重復(fù)生成相同的項(xiàng)

例如,我們可以得到三個(gè)相同的“Yang”,如下所示:


import itertools
print(list(itertools.repeat('Yang', 3)))
# ['Yang', 'Yang', 'Yang']


itertools.cycle(): 通過(guò)循環(huán)獲得無(wú)限迭代器

itertools.cycle函數(shù)將不會(huì)停止,直到我們跳出循環(huán):


import itertools


count = 0


for c in itertools.cycle('Yang'):
    if count >= 12:
        break
    else:
        print(c, end=',')
        count += 1
# Y,a,n,g,Y,a,n,g,Y,a,n,g,
itertools.count(): 生成一個(gè)無(wú)限的數(shù)字序列 如果我們只需要數(shù)字,可以使用itertools.count函數(shù):

import itertools


for i in itertools.count(0, 2):
    if i == 20:
        break
    else:
        print(i, end=" ")
# 0 2 4 6 8 10 12 14 16 18


如上所示,它的第一個(gè)參數(shù)是起始數(shù)字,第二個(gè)參數(shù)是步長(zhǎng)。

8、itertools.pairwise(): 輕松獲取成對(duì)的元組

自從Python 3.10版本開(kāi)始,itertools模塊新增了一個(gè)名為pairwise的函數(shù)。它是一個(gè)簡(jiǎn)潔而方便的工具,用于從可迭代對(duì)象中生成連續(xù)的重疊對(duì)。


import itertools


letters = ['a', 'b', 'c', 'd', 'e']


result = itertools.pairwise(letters)


print(list(result))
# [('a', 'b'), ('b', 'c'), ('c', 'd'), ('d', 'e')]
c67406ce-fa29-11ed-90ce-dac502259ad0.png

9、itertools.takewhile(): 以不同的方式過(guò)濾元素

itertools.takewhile()返回一個(gè)迭代器,只要給定的謂詞函數(shù)評(píng)估為T(mén)rue,就會(huì)從可迭代對(duì)象中生成元素。


import itertools


nums = [1, 61, 7, 9, 2077]


print(list(itertools.takewhile(lambda x: x < 100, nums)))
# [1, 61, 7, 9]
該函數(shù)與內(nèi)置的filter()函數(shù)不同。

filter函數(shù)將遍歷整個(gè)列表:

nums = [1, 61, 7, 9, 2077]


print(list(filter(lambda x: x < 10, nums)))
# [1, 7, 9]
然而,itertools.takewhile函數(shù)如其名稱所示,當(dāng)評(píng)估函數(shù)為False時(shí)會(huì)停止迭代:

import itertools


nums = [1, 61, 7, 9, 2077]


print(list(itertools.takewhile(lambda x: x < 10, nums)))
# [1]

10、itertools.dropwhile(): itertools.takewhile的反向操作

這個(gè)函數(shù)似乎是前面那個(gè)函數(shù)的相反思路。

itertools.takewhile()函數(shù)在謂詞函數(shù)為T(mén)rue時(shí)返回可迭代對(duì)象的元素,而itertools.dropwhile()函數(shù)在謂詞函數(shù)為T(mén)rue時(shí)丟棄可迭代對(duì)象的元素,然后返回剩下的元素。


import itertools


nums = [1, 61, 7, 9, 2077]


print(list(itertools.dropwhile(lambda x: x < 100, nums)))
# [2077]

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11125

    瀏覽量

    207928
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4238

    瀏覽量

    61976
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4671

    瀏覽量

    67778
  • python
    +關(guān)注

    關(guān)注

    53

    文章

    4753

    瀏覽量

    84084

原文標(biāo)題:10 個(gè) Python Itertools,讓你的代碼如虎添翼

文章出處:【微信號(hào):Linux迷,微信公眾號(hào):Linux迷】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    10個(gè)殺手級(jí)的Python自動(dòng)化腳本

    今天浩道跟大家分享10個(gè)日常工作中用到的python自動(dòng)化腳本。感受一番python簡(jiǎn)單強(qiáng)大
    發(fā)表于 11-28 11:07 ?640次閱讀

    Python面試必看的10個(gè)問(wèn)題

    :delaelse:last=aprint(a)10、下面的代碼Python2中的輸出是什么?解釋的答案defdiv1(x,y): print "%s/%s = %s" % (x
    發(fā)表于 02-28 17:00

    Labview與Python的網(wǎng)絡(luò)編程

    Labview素有測(cè)試之王的美譽(yù),圖形化編程和快速搭建自動(dòng)化平臺(tái)人愛(ài)不釋手。但是Labview不能在安卓平臺(tái)上運(yùn)行,開(kāi)發(fā)web也力不從心。如果labview配合上Python簡(jiǎn)直就如虎添翼
    發(fā)表于 11-12 13:48

    10Python功力,總結(jié)了10個(gè)開(kāi)發(fā)技巧,非常實(shí)用

    read 函數(shù),其實(shí) Python 會(huì)將文件的內(nèi)容一次性的全部載入內(nèi)存中,如果文件有 10 個(gè)G甚至更多,那么的電腦就要消耗的內(nèi)存非常巨大。# 一次性讀取with open(&qu
    發(fā)表于 08-26 11:58

    Python 代碼優(yōu)雅又地道

    Python社區(qū)文化的澆灌下,演化出了一種獨(dú)特的代碼風(fēng)格,去指導(dǎo)如何正確地使用Python,這就是常說(shuō)的pythonic。一般說(shuō)地道(idiomatic)的python
    的頭像 發(fā)表于 03-06 10:35 ?3546次閱讀

    Python系統(tǒng)庫(kù)itertools的詳細(xì)資料介紹

    很多人都致力于把Python代碼寫(xiě)得更Pythonic,一來(lái)更符合規(guī)范且容易閱讀,二來(lái)一般Pythonic的代碼在執(zhí)行上也更有效率。今天就先給大家介紹一下Python的系統(tǒng)庫(kù)
    的頭像 發(fā)表于 06-18 17:08 ?3087次閱讀

    7個(gè)Python調(diào)試通過(guò)的代碼詳細(xì)資料分析

    "Python的應(yīng)用十分廣泛,今天我們來(lái)分享7個(gè)Python實(shí)戰(zhàn)項(xiàng)目代碼,希望你有所收獲。
    的頭像 發(fā)表于 10-14 09:46 ?3365次閱讀

    Python 代碼加速運(yùn)行的的小技巧

    的技巧進(jìn)行整理。 0. 代碼優(yōu)化原則本文會(huì)介紹不少的 Python 代碼加速運(yùn)行的技巧。在深入代碼優(yōu)化細(xì)節(jié)之前,需要了解一些代碼優(yōu)化基本原則
    的頭像 發(fā)表于 09-01 11:28 ?1608次閱讀

    一些值得玩味的python代碼

    選取了 6 個(gè)自己認(rèn)為值得玩味的 python 代碼,希望對(duì)正在學(xué)習(xí) python有所幫助。
    的頭像 發(fā)表于 03-30 17:32 ?1582次閱讀

    10種聚類介紹和Python代碼

    分享一篇關(guān)于聚類的文章,10種聚類介紹和Python代碼。
    的頭像 發(fā)表于 07-30 10:25 ?2869次閱讀

    20個(gè)解決日常問(wèn)題的Python代碼片段!

    在本文中,將分享20 個(gè) Python 代碼片段,以幫助你應(yīng)對(duì)日常編程挑戰(zhàn)。可能已經(jīng)知道其中一些片段,但有些其他片段對(duì)來(lái)說(shuō)可能是新的。趕
    的頭像 發(fā)表于 03-13 09:40 ?912次閱讀

    深度學(xué)習(xí)如何Turing 顯卡如虎添翼

    NVIDIA 首席執(zhí)行官暢談深度學(xué)習(xí) Turing 顯卡如虎添翼
    的頭像 發(fā)表于 08-01 14:55 ?482次閱讀

    Yapf:一個(gè)格式化 Python 代碼的好幫手

    格式化為符合 PEP8 代碼指南的格式,還能格式化為符合 Google 代碼指南的格式,可選項(xiàng)更多,代碼更加漂亮。 1.準(zhǔn)備 開(kāi)始之前
    的頭像 發(fā)表于 10-17 11:08 ?640次閱讀
    Yapf:一<b class='flag-5'>個(gè)</b>格式化 <b class='flag-5'>Python</b> <b class='flag-5'>代碼</b>的好幫手

    python代碼寫(xiě)完后點(diǎn)哪個(gè)運(yùn)行

    或命令行界面,輸入命令 python ,然后將你的代碼粘貼到解釋器提示符 >>> 后面,按下回車即可運(yùn)行代碼。 集成開(kāi)發(fā)環(huán)境(IDE):IDE是一種提供代碼編輯、調(diào)試、運(yùn)行等功能的開(kāi)發(fā)
    的頭像 發(fā)表于 11-24 09:28 ?2866次閱讀

    python軟件怎么運(yùn)行代碼

    Python是一種高級(jí)編程語(yǔ)言,它被廣泛用于開(kāi)發(fā)各種類型的應(yīng)用程序,從簡(jiǎn)單的腳本到復(fù)雜的網(wǎng)絡(luò)應(yīng)用和機(jī)器學(xué)習(xí)模型。要運(yùn)行Python代碼,您需要一個(gè)P
    的頭像 發(fā)表于 11-28 16:02 ?747次閱讀