python迭代

什么是迭代


在一般語(yǔ)言中, 我們通常有這么一種for循環(huán)

for (i=0; i<list.length; i++) {
    n = list[i];
}

這種遍歷我們稱之為迭代(Iteration)
但是在python中, 并沒(méi)有提供這樣的for循環(huán), 因此在Python中, 我們通過(guò)for ... in來(lái)完成迭代, 比如

for i in range(1,100):
    if i%7 == 0:
        print i,
    else:
        continue

Python 的 for循環(huán)不僅可以用在list或tuple上,還可以作用在其他任何可迭代對(duì)象上沼填。
因此,迭代操作就是對(duì)于一個(gè)集合嗜逻,無(wú)論該集合是有序還是無(wú)序龙宏,我們用 for 循環(huán)總是可以依次取出集合的每一個(gè)元素。

注意:Python中我們常用的集合包括:

  1. 有序集合:list杏节,tuple唯竹,str和unicode乐导;
  2. 無(wú)序集合:set
  3. 無(wú)序集合并且具有 key-value 對(duì):dict

迭代是一個(gè)動(dòng)詞,它指的是一種操作浸颓,在Python中物臂,就是 for 循環(huán)


索引迭代


Python中,迭代永遠(yuǎn)是取出元素本身产上,而非元素的索引棵磷。

通常情況下我們用for...in迭代是沒(méi)辦法拿到有序集合的索引的, 但是我們可以通過(guò)enumerate() 函數(shù)拿到有序集合的索引

L = ['Adam', 'Lisa', 'Bart', 'Paul']
for index, name in enumerate(L):
    print index, '-', name

0 - Adam
1 - Lisa
2 - Bart
3 - Paul

為什么enumerate() 函數(shù)可以拿到有序集合的索引呢?

enumerate() 函數(shù)把:

['Adam', 'Lisa', 'Bart', 'Paul']

變成了類似:

[(0, 'Adam'), (1, 'Lisa'), (2, 'Bart'), (3, 'Paul')]

因此,迭代的每一個(gè)元素實(shí)際上是一個(gè)tuple, 因此我們最開(kāi)始的代碼相當(dāng)于

for t in enumerate(L):
    index = t[0]
    name = t[1]
    print index, '-', name


迭代dict


迭代dict的value

dict是一個(gè)可迭代對(duì)象, 通常用for循環(huán)迭代dict每次都拿到dict的一個(gè)key

如果我們想迭代dict對(duì)象的value,可以使用 dict 對(duì)象的 values() 方法晋涣,這個(gè)方法把dict轉(zhuǎn)換成一個(gè)包含所有value的list

d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 }
print d.values()


# [85, 95, 59]


for v in d.values():
    print v


# 85
# 95
# 59

dict除了values()方法外仪媒,還有一個(gè) itervalues() 方法,用 itervalues() 方法替代 values() 方法姻僧,迭代效果完全一樣:

d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 }
print d.itervalues()


# <dictionary-valueiterator object at 0x106adbb50>


for v in d.itervalues():
    print v


# 85
# 95
# 59

那這兩個(gè)方法有何不同之處呢规丽?

  1. values() 方法實(shí)際上把一個(gè) dict 轉(zhuǎn)換成了包含 value 的list。

  2. itervalues() 方法不會(huì)轉(zhuǎn)換撇贺,它會(huì)在迭代過(guò)程中依次從 dict 中取出 value赌莺,所以 itervalues() 方法比 values() 方法節(jié)省了生成 list 所需的內(nèi)存。

  3. 打印 itervalues() 發(fā)現(xiàn)它返回一個(gè) <dictionary-valueiterator> 對(duì)象松嘶,這說(shuō)明在Python中艘狭,for 循環(huán)可作用的迭代對(duì)象遠(yuǎn)不止 list,tuple翠订,str巢音,unicode,dict等尽超,任何可迭代對(duì)象都可以作用于for循環(huán)官撼,而內(nèi)部如何迭代我們通常并不用關(guān)心

如果一個(gè)對(duì)象說(shuō)自己可迭代,那我們就直接用 for 循環(huán)去迭代它似谁,可見(jiàn)傲绣,迭代是一種抽象的數(shù)據(jù)操作,它不對(duì)迭代對(duì)象內(nèi)部的數(shù)據(jù)有任何要求


迭代dict的key和value

利用dict 對(duì)象的 items() 方法可以同時(shí)迭代dict的key和value

們看看 dict 對(duì)象的 items() 方法返回的值:

 d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 }
 print d.items()


[('Lisa', 85), ('Adam', 95), ('Bart', 59)]

可以看到巩踏,items() 方法把dict對(duì)象轉(zhuǎn)換成了包含tuple的list秃诵,我們對(duì)這個(gè)list進(jìn)行迭代,可以同時(shí)獲得key和value:

for key, value in d.items():
print key, ':', value

Lisa : 85
Adam : 95
Bart : 59

和 values() 有一個(gè) itervalues() 類似塞琼, items() 也有一個(gè)對(duì)應(yīng)的 iteritems()菠净,iteritems() 不把dict轉(zhuǎn)換成list,而是在迭代過(guò)程中不斷給出 tuple彪杉,所以毅往, iteritems() 不占用額外的內(nèi)存。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末在讶,一起剝皮案震驚了整個(gè)濱河市煞抬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌构哺,老刑警劉巖革答,帶你破解...
    沈念sama閱讀 211,743評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異曙强,居然都是意外死亡残拐,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)碟嘴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)溪食,“玉大人,你說(shuō)我怎么就攤上這事娜扇〈砦郑” “怎么了栅组?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,285評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)枢析。 經(jīng)常有香客問(wèn)我玉掸,道長(zhǎng),這世上最難降的妖魔是什么醒叁? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,485評(píng)論 1 283
  • 正文 為了忘掉前任司浪,我火速辦了婚禮,結(jié)果婚禮上把沼,老公的妹妹穿的比我還像新娘啊易。我一直安慰自己,他們只是感情好饮睬,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,581評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布租谈。 她就那樣靜靜地躺著,像睡著了一般续捂。 火紅的嫁衣襯著肌膚如雪垦垂。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,821評(píng)論 1 290
  • 那天牙瓢,我揣著相機(jī)與錄音劫拗,去河邊找鬼。 笑死矾克,一個(gè)胖子當(dāng)著我的面吹牛页慷,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播胁附,決...
    沈念sama閱讀 38,960評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼酒繁,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了控妻?” 一聲冷哼從身側(cè)響起州袒,我...
    開(kāi)封第一講書(shū)人閱讀 37,719評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎弓候,沒(méi)想到半個(gè)月后郎哭,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,186評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡菇存,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,516評(píng)論 2 327
  • 正文 我和宋清朗相戀三年夸研,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片依鸥。...
    茶點(diǎn)故事閱讀 38,650評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡亥至,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情姐扮,我是刑警寧澤絮供,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站茶敏,受9級(jí)特大地震影響杯缺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜睡榆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,936評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望袍榆。 院中可真熱鬧胀屿,春花似錦、人聲如沸包雀。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,757評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)才写。三九已至葡兑,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間赞草,已是汗流浹背讹堤。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,991評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留厨疙,地道東北人洲守。 一個(gè)月前我還...
    沈念sama閱讀 46,370評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像沾凄,于是被迫代替她去往敵國(guó)和親梗醇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,527評(píng)論 2 349

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

  • 一撒蟀、python 變量和數(shù)據(jù)類型 1.整數(shù) Python可以處理任意大小的整數(shù)叙谨,當(dāng)然包括負(fù)整數(shù),在Python程序...
    績(jī)重KF閱讀 1,660評(píng)論 0 1
  • 最近在慕課網(wǎng)學(xué)習(xí)廖雪峰老師的Python進(jìn)階課程保屯,做筆記總結(jié)一下重點(diǎn)手负。 基本變量及其類型 變量 在Python中,...
    victorsungo閱讀 1,667評(píng)論 0 5
  • 與或運(yùn)算 在計(jì)算 a and b 時(shí)配椭,如果 a 是 False虫溜,則根據(jù)與運(yùn)算法則,整個(gè)結(jié)果必定為 False股缸,因此...
    張文靖同學(xué)閱讀 310評(píng)論 0 1
  • 0. 序言 python 是一門(mén)腳本語(yǔ)言:封裝性強(qiáng)衡楞,語(yǔ)法簡(jiǎn)潔,開(kāi)發(fā)效率高,只用函數(shù)open就可以打開(kāi)一個(gè)txt文件...
    付凱強(qiáng)閱讀 1,221評(píng)論 0 5
  • 最近臨的水彩風(fēng)景瘾境,分享一下過(guò)程圖~ 使用的畫(huà)材: 寶虹水彩紙歧杏,粗紋300g;梵高固體水彩 過(guò)程如下: 1迷守、鉛筆打線...
    貳蚊閱讀 6,962評(píng)論 10 77