itertools

Python的內(nèi)建模塊itertools提供了非常有用的用于操作迭代對象的函數(shù)。

首先罪塔,我們看看itertools提供的幾個“無限”迭代器:

>>> import itertools
>>> natuals = itertools.count(1)
>>> for n in natuals:
...     print(n)
...
1
2
3
...

因為count()會創(chuàng)建一個無限的迭代器角骤,所以上述代碼會打印出自然數(shù)序列隅忿,根本停不下來,只能按Ctrl+C退出邦尊。

cycle()會把傳入的一個序列無限重復下去:

>>> import itertools
>>> cs = itertools.cycle('ABC') # 注意字符串也是序列的一種
>>> for c in cs:
...     print(c)
...
'A'
'B'
'C'
'A'
'B'
'C'
...

同樣停不下來背桐。

repeat()負責把一個元素無限重復下去,不過如果提供第二個參數(shù)就可以限定重復次數(shù):

>>> ns = itertools.repeat('A', 3)
>>> for n in ns:
...     print(n)
...
A
A
A

無限序列只有在for迭代時才會無限地迭代下去蝉揍,如果只是創(chuàng)建了一個迭代對象链峭,它不會事先把無限個元素生成出來,事實上也不可能在內(nèi)存中創(chuàng)建無限多個元素又沾。

無限序列雖然可以無限迭代下去弊仪,但是通常我們會通過takewhile()等函數(shù)根據(jù)條件判斷來截取出一個有限的序列:

>>> natuals = itertools.count(1)
>>> ns = itertools.takewhile(lambda x: x <= 10, natuals)
>>> list(ns)
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

itertools提供的幾個迭代器操作函數(shù)更加有用:

chain()

chain()可以把一組迭代對象串聯(lián)起來熙卡,形成一個更大的迭代器:

>>> for c in itertools.chain('ABC', 'XYZ'):
...     print(c)
# 迭代效果:'A' 'B' 'C' 'X' 'Y' 'Z'

groupby()

groupby()把迭代器中相鄰的重復元素挑出來放在一起:

>>> for key, group in itertools.groupby('AAABBBCCAAA'):
...     print(key, list(group))
...
A ['A', 'A', 'A']
B ['B', 'B', 'B']
C ['C', 'C']
A ['A', 'A', 'A']

實際上挑選規(guī)則是通過函數(shù)完成的,只要作用于函數(shù)的兩個元素返回的值相等励饵,這兩個元素就被認為是在一組的驳癌,而函數(shù)返回值作為組的key。如果我們要忽略大小寫分組曲横,就可以讓元素'A''a'都返回相同的key:

>>> for key, group in itertools.groupby('AaaBBbcCAAa', lambda c: c.upper()):
...     print(key, list(group))
...
A ['A', 'a', 'a']
B ['B', 'B', 'b']
C ['c', 'C']
A ['A', 'A', 'a']

練習

計算圓周率可以根據(jù)公式:

利用Python提供的itertools模塊喂柒,我們來計算這個序列的前N項和:

import  itertools


def pi(N):
    ' 計算pi的值 '
    # step 1: 創(chuàng)建一個奇數(shù)序列: 1, 3, 5, 7, 9, ...
    odds = itertools.count(1, 2)

    # step 2: 取該序列的前N項: 1, 3, 5, 7, 9, ..., 2*N-1.
    odd_iter = itertools.takewhile(lambda x: x < 2*N, odds)

    # step 3: 添加正負符號并用4除: 4/1, -4/3, 4/5, -4/7, 4/9, ...
    lst = [4.0/i*(-1)**(i//2) for i in odd_iter]

    # step 4: 求和:
    return sum(lst)


print(pi(1000000))

小結(jié)
itertools模塊提供的全部是處理迭代功能的函數(shù),它們的返回值不是list禾嫉,而是Iterator灾杰,只有用for循環(huán)迭代的時候才真正計算。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末熙参,一起剝皮案震驚了整個濱河市艳吠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌孽椰,老刑警劉巖昭娩,帶你破解...
    沈念sama閱讀 219,110評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異黍匾,居然都是意外死亡栏渺,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評論 3 395
  • 文/潘曉璐 我一進店門锐涯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來磕诊,“玉大人,你說我怎么就攤上這事纹腌■眨” “怎么了?”我有些...
    開封第一講書人閱讀 165,474評論 0 356
  • 文/不壞的土叔 我叫張陵升薯,是天一觀的道長莱褒。 經(jīng)常有香客問我,道長涎劈,這世上最難降的妖魔是什么广凸? 我笑而不...
    開封第一講書人閱讀 58,881評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮责语,結(jié)果婚禮上炮障,老公的妹妹穿的比我還像新娘。我一直安慰自己坤候,他們只是感情好胁赢,可當我...
    茶點故事閱讀 67,902評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著白筹,像睡著了一般智末。 火紅的嫁衣襯著肌膚如雪谅摄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,698評論 1 305
  • 那天系馆,我揣著相機與錄音送漠,去河邊找鬼。 笑死由蘑,一個胖子當著我的面吹牛闽寡,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播尼酿,決...
    沈念sama閱讀 40,418評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼爷狈,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了裳擎?” 一聲冷哼從身側(cè)響起涎永,我...
    開封第一講書人閱讀 39,332評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎鹿响,沒想到半個月后羡微,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,796評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡惶我,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,968評論 3 337
  • 正文 我和宋清朗相戀三年妈倔,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绸贡。...
    茶點故事閱讀 40,110評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡启涯,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出恃轩,到底是詐尸還是另有隱情,我是刑警寧澤黎做,帶...
    沈念sama閱讀 35,792評論 5 346
  • 正文 年R本政府宣布叉跛,位于F島的核電站,受9級特大地震影響蒸殿,放射性物質(zhì)發(fā)生泄漏筷厘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,455評論 3 331
  • 文/蒙蒙 一宏所、第九天 我趴在偏房一處隱蔽的房頂上張望酥艳。 院中可真熱鬧,春花似錦爬骤、人聲如沸充石。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽骤铃。三九已至拉岁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間惰爬,已是汗流浹背喊暖。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留撕瞧,地道東北人陵叽。 一個月前我還...
    沈念sama閱讀 48,348評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像丛版,于是被迫代替她去往敵國和親巩掺。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,047評論 2 355

推薦閱讀更多精彩內(nèi)容

  • PYTHON-進階-ITERTOOLS模塊小結(jié)轉(zhuǎn)自wklken:http://wklken.me/posts/20...
    C_Y_閱讀 968評論 0 2
  • 1 itertools函數(shù) 以下模塊級別函數(shù)都構(gòu)造并返回iterator硼婿。有些iterator是無限長度的流锌半,因此...
    lakerszhy閱讀 1,046評論 0 3
  • 本文翻譯自Functional Programming Howto 本文將介紹Python中函數(shù)式編程的特性。在對...
    大蟒傳奇閱讀 2,617評論 4 14
  • 介紹 itertools是python內(nèi)置的模塊寇漫,提供了若干個用于操作迭代對象的函數(shù)刊殉,使用簡單且功能強大。方便以后...
    52_St閱讀 1,005評論 0 0
  • 這幾天一直加班到晚上10點州胳,所以一直滴滴打車回家记焊。期間和不同司機進行交流,最讓我印象深刻的是周五拉我回家的河南司機...
    啦啦啦啦哈哈哈哈哈哈哈閱讀 367評論 2 0