在Python中碍现,如果給定一個(gè)list或tuple,我們可以通過for循環(huán)來遍歷這個(gè)list或tuple米奸,這種遍歷我們成為迭代(Iteration)昼接。
在Python中,迭代是通過for ... in?來完成的悴晰,而很多語言比如C或者Java慢睡,迭代list是通過下標(biāo)完成的,可以看出铡溪,Python的for循環(huán)抽象程度要高于Java的for循環(huán)漂辐。
因?yàn)?Python 的 for循環(huán)不僅可以用在list或tuple上,還可以作用在其他任何可迭代對(duì)象上棕硫。因此髓涯,迭代操作就是對(duì)于一個(gè)集合,無論該集合是有序還是無序哈扮,我們用 for 循環(huán)總是可以依次取出集合的每一個(gè)元素纬纪。
注意: 集合是指包含一組元素的數(shù)據(jù)結(jié)構(gòu),我們已經(jīng)介紹的包括:
1.有序集合:list滑肉,tuple包各,str和unicode;
2.無序集合:set
3.無序集合并且具有 key-value 對(duì):dict
而迭代是一個(gè)動(dòng)詞赦邻,它指的是一種操作髓棋,在Python中,就是 for 循環(huán)惶洲。
迭代與按下標(biāo)訪問數(shù)組最大的不同是按声,后者是一種具體的迭代實(shí)現(xiàn)方式,而前者只關(guān)心迭代結(jié)果恬吕,根本不關(guān)心迭代內(nèi)部是如何實(shí)現(xiàn)的签则。
9.1 索引迭代
Python中,迭代永遠(yuǎn)是取出元素本身铐料,而非元素的索引渐裂。
對(duì)于有序集合,元素確實(shí)是有索引的钠惩。有的時(shí)候柒凉,我們確實(shí)想在 for 循環(huán)中拿到索引,怎么辦篓跛?
方法是使用enumerate() 函數(shù):
>>> L = ['Adam', 'Lisa', 'Bart', 'Paul']
>>>forindex, name? in? enumerate(L):
...? ? print index, '-', name
... 0 - Adam
1- Lisa
2 - Bart
3 - Paul
使用 enumerate() 函數(shù)膝捞,我們可以在for循環(huán)中同時(shí)綁定索引index和元素name。但是愧沟,這不是 enumerate() 的特殊語法蔬咬。實(shí)際上鲤遥,enumerate() 函數(shù)把:['Adam', 'Lisa', 'Bart', 'Paul']變成了類似:[(0, 'Adam'), (1, 'Lisa'), (2, 'Bart'), (3, 'Paul')]
因此盖奈,迭代的每一個(gè)元素實(shí)際上是一個(gè)tuple钢坦,這樣不但代碼更簡(jiǎn)單啥酱,而且還少了兩條賦值語句。
可見,索引迭代也不是真的按索引訪問泳猬,而是由 enumerate() 函數(shù)自動(dòng)把每個(gè)元素變成 (index, element) 這樣的tuple得封,再迭代,就同時(shí)獲得了索引和元素本身拷呆。
9.2 迭代dict的value
我們已經(jīng)了解了dict對(duì)象本身就是可迭代對(duì)象疫粥,用 for 循環(huán)直接迭代 dict,可以每次拿到dict的一個(gè)key项秉。
如果我們希望迭代 dict 對(duì)象的value娄蔼,應(yīng)該怎么做底哗?
dict 對(duì)象有一個(gè)values() 方法,這個(gè)方法把dict轉(zhuǎn)換成一個(gè)包含所有value的list涕癣,這樣属划,我們迭代的就是 dict的每一個(gè) value。
如果仔細(xì)閱讀Python的文檔同眯,還可以發(fā)現(xiàn),dict除了values()方法外硅确,還有一個(gè) itervalues() 方法菱农,用 itervalues()方法替代values()方法柿估,迭代效果完全一樣。
那這兩個(gè)方法有何不同之處呢的妖?
1.values()方法實(shí)際上把一個(gè) dict 轉(zhuǎn)換成了包含 value 的list足陨。
2. 但是itervalues()方法不會(huì)轉(zhuǎn)換墨缘,它會(huì)在迭代過程中依次從 dict 中取出 value,所以 itervalues() 方法比 values() 方法節(jié)省了生成 list 所需的內(nèi)存宽涌。
3.?打印 itervalues() 發(fā)現(xiàn)它返回一個(gè) 對(duì)象蝶棋,這說明在Python中,for 循環(huán)可作用的迭代對(duì)象遠(yuǎn)不止 list嫡良,tuple寝受,str,unicode很澄,dict等甩苛,任何可迭代對(duì)象都可以作用于for循環(huán),而內(nèi)部如何迭代我們通常并不用關(guān)心痊土。
如果一個(gè)對(duì)象說自己可迭代,那我們就直接用 for 循環(huán)去迭代它赁酝,可見酌呆,迭代是一種抽象的數(shù)據(jù)操作搔耕,它不對(duì)迭代對(duì)象內(nèi)部的數(shù)據(jù)有任何要求。
9.3 迭代dict的key和value
我們了解了如何迭代 dict的key和value弃榨,那么惭墓,在一個(gè) for 循環(huán)中腊凶,能否同時(shí)迭代 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尚镰,而是在迭代過程中不斷給出 tuple哪廓,所以, iteritems() 不占用額外的內(nèi)存敞曹。