成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

簡潔編程之道,十個Python Itertools方法助你事半功倍

開發 前端
Python的編程優勢在于它的簡潔性。這不僅是因為Python語法優雅,還因為它有許多精心設計的內置模塊,可以幫助開發者高效地實現常用功能。

簡介

Python的編程優勢在于它的簡潔性。這不僅是因為Python語法優雅,還因為它有許多精心設計的內置模塊,可以幫助開發者高效地實現常用功能。

itertools模塊就是一個很好的例子,它為開發者提供了許多強大的工具,可以用更短的代碼來操作Python的可迭代對象,幫助開發者事半功倍地完成任務。

1. itertools.product():避免嵌套循環的巧妙方式

當程序變得越來越復雜時,可能需要編寫嵌套循環。與此同時,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

如何改進上述代碼,使其具有Python風格?

可以使用itertools.product()函數:

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

如上所示,它返回輸入可迭代對象的笛卡爾積,幫助將3個嵌套的for循環合并為一個。

2. itertools.compress():過濾數據的便捷方式

可以通過一個或多個循環來過濾列表中的項目。

但有時候,可能不需要編寫任何循環,而是使用函數itertools.compress()。

itertools.compress()函數返回一個迭代器,該迭代器根據對應的布爾掩碼值對可迭代對象進行過濾。

例如,以下代碼使用itertools.compress()函數選擇真正的數據:

import itertools
leaders = ['Yang', 'Elon', 'Tim', 'Tom', 'Mark']
selector = [1, 1, 0, 0, 0]
print(list(itertools.compress(leaders, selector)))
# ['Yang', 'Elon']

第二個參數selector作為一個掩碼,也可以定義為以下形式:

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

3. itertools.groupby():對可迭代對象進行分組

itertools.groupby()函數是將可迭代對象中相鄰的重復元素進行分組的一種便捷方式。

例如,可以對一個長字符串進行如下分組:

from itertools import groupby

for key, group in groupby('YAaANNGGG'):
    print(key, list(group))
# Y ['Y']
# A ['A']
# a ['a']
# A ['A']
# N ['N', 'N']
# G ['G', 'G', 'G']

此外,還可以利用它的第二個參數來告訴groupby()函數如何判斷兩個元素是否相同:

from itertools import groupby

for key, group in groupby('YAaANNGGG', lambda x: x.upper()):
    print(key, list(group))
# Y ['Y']
# A ['A', 'a', 'A']
# N ['N', 'N']
# G ['G', 'G', 'G']

4. itertools.combinations():獲取可迭代對象中給定長度的所有組合

對于初學者來說,編寫一個正確的函數來獲取列表的所有可能組合可能需要一些時間。

實際上,如果使用itertools.combinations()函數,可以很容易地實現:

import itertools

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

result = itertools.combinations(author, 2)

for x in result:
    print(x)
# ('Y', 'a')
# ('Y', 'n')
# ('Y', 'g')
# ('a', 'n')
# ('a', 'g')
# ('n', 'g')

如上述程序所示,itertools.combinations()函數有兩個參數,一個是原始可迭代對象,另一個是函數生成的子序列的長度。

5. itertools.permutations(): 獲取可迭代對象中給定長度的所有排列

既然有一個函數可以獲取所有組合,當然還有另一個名為itertools.permutations的函數可以獲取所有可能的排列:

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()函數的使用方式與itertools.combinations()函數類似。唯一的區別在于它們的結果。

6. itertools.accumulate():從可迭代對象生成累積項

基于可迭代對象獲取一系列累積值是一種常見的需求。借助itertools.accumulate()函數的幫助,不需要編寫任何循環就能實現。

import itertools
import operator

nums = [1, 2, 3, 4, 5]
print(list(itertools.accumulate(nums, operator.mul)))
# [1, 2, 6, 24, 120]

如果不想使用operator.mul,上述程序與以下程序相同:

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():創建無限迭代器

在某些情況下,開發者需要獲得一個無限迭代器。有3個函數可以幫助實現:

7.1 itertools.repeat():重復生成相同的項目

例如,可以按以下方式獲取三個相同的“Yang”:

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

7.2 itertools.cycle():通過循環獲取無限迭代器

itertools.cycle函數在中斷循環之前不會停止:

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,

7.3 itertools.count():生成一個無限的數字序列

如果需要的只是數字,可以使用itertools.count函數:

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

如上所示,它的第一個參數是起始數字,第二個參數是步長。

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

自Python 3.10以來,itertools模塊新增了一個名為pairwise的新函數。它是一個簡潔的工具,可以從可迭代對象生成連續重疊的成對元素。

import itertools

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

result = itertools.pairwise(letters)

print(list(result))
# [('a', 'b'), ('b', 'c'), ('c', 'd'), ('d', 'e')]

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

itertools.takewhile()返回一個迭代器,只要給定的謂詞函數評估為True,該迭代器就會生成可迭代對象中的元素。

import itertools

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

print(list(itertools.takewhile(lambda x: x < 100, nums)))
# [1, 61, 7, 9]

此函數與內置的filter()函數不同。

filter函數將遍歷整個列表:

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

print(list(filter(lambda x: x < 10, nums)))
# [1, 7, 9]

然而,itertools.takewhile函數會在評估函數為False時停止:

import itertools

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

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

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

這個函數是上一個函數的逆操作。

itertools.takewhile()函數在True時返回可迭代對象中的元素,而itertools.dropwhile()函數會在True時刪除可迭代對象的元素,并返回剩余的元素。

import itertools

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

print(list(itertools.dropwhile(lambda x: x < 100, nums)))
# [2077]
責任編輯:武曉燕 來源: Python學研大本營
相關推薦

2023-12-22 15:44:43

2023-05-24 10:24:56

代碼Python

2023-10-29 17:12:26

Python編程

2024-05-28 14:36:00

Python開發

2024-09-09 18:18:45

2024-01-30 00:40:10

2023-10-04 19:38:01

插件主題IntelliJ

2023-10-31 19:28:48

GitHub存儲前端

2024-12-02 06:00:00

Python變量代碼

2024-01-12 07:32:35

數據科學Python庫項目

2010-09-02 09:21:45

CSS兼容

2022-05-07 14:08:42

Python自動化腳本

2024-05-21 11:14:20

Python編程

2024-09-23 12:00:00

Python編程

2023-05-28 22:48:29

程序員編程

2023-04-20 18:45:44

2022-08-28 19:03:18

JavaScript編程語言開發

2015-07-30 14:45:19

java簡潔

2024-07-18 15:08:27

2024-11-01 08:00:00

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩中文视频 | 欧美日韩1区2区 | 午夜黄色 | 亚洲精品自在在线观看 | 久久久久国产 | 一二区视频 | 国产欧美性成人精品午夜 | av片免费 | 欧洲精品久久久久毛片完整版 | 二区在线视频 | aaaa网站 | 情侣酒店偷拍一区二区在线播放 | 欧美日韩亚洲一区二区 | 成人在线免费 | 国产一区二区三区免费观看视频 | 久久亚洲国产精品 | 亚洲品质自拍视频网站 | 成人免费区一区二区三区 | 日本精品裸体写真集在线观看 | 国产精品毛片无码 | 欧美精品在线一区 | 午夜影院在线观看 | 九一在线 | 午夜天堂精品久久久久 | 91视频官网 | 免费日韩网站 | 一区二区三区亚洲视频 | 中文无吗 | 日韩免费一区二区 | 欧美精品一区二区三区在线播放 | 国产精品久久久一区二区三区 | 精品自拍视频 | 国产精品视频在线观看 | 久久99深爱久久99精品 | 国产激情三区 | 久久久高清 | 美女爽到呻吟久久久久 | 国产视频精品区 | 国产成人午夜电影网 | 久久久一二三区 | 午夜精品久久久久久久久久久久 |