range()
在 Python 中,for 迴圈後的 in 跟隨一個序列的話,迴圈每次使用的序列元素,而不是序列的下標。
之前我們已經使用過 range() 來控制 for 迴圈。現在,我們繼續開發 range 的功能,以實現下標對迴圈的控制:

S = ‘abcdefghijk’
for i in range(0,len(S),2):
print S[i]

在該例子中,我們利用 len() 函式和 range() 函式,用 i 作為 S 序列的下標來控制迴圈。在 range 函式中,分別定義上限,下限和每次迴圈的步長。這就和 C 語言中的 for 迴圈相類似了。
 
enumerate()
利用 enumerate() 函式,可以在每次迴圈中同時得到下標和元素:

S = ‘abcdefghijk’
for (index,char) in enumerate(S):
print index
print char

實際上,enumerate() 在每次迴圈中,返回的是一個包含兩個元素的定值表 (tuple),兩個元素分別賦予 index 和 char
 
zip()
如果你多個等長的序列,然後想要每次迴圈時從各個序列分別取出一個元素,可以利用 zip() 方便地實現:

ta = [1,2,3]
tb = [9,8,7]
tc = [‘a’,’b’,’c’]
for (a,b,c) in zip(ta,tb,tc):
print(a,b,c)

每次迴圈時,從各個序列分別從左到右取出一個元素,合併成一個 tuple,然後 tuple 的元素賦予給 a,b,c
zip() 函式的功能,就是從多個列表中,依次各取出一個元素。每次取出的 (來自不同列表的) 元素合成一個元組,合併成的元組放入 zip() 返回的列表中。 zip() 函式起到了聚合列表的功能。
 
我們可以分解聚合後的列表,如下:

ta = [1,2,3]
tb = [9,8,7]

# cluster
zipped = zip(ta,tb)
print(zipped)

# decompose
na, nb = zip(*zipped)
print(na, nb)

 
總結
range()
enumerate()
zip()

 
作者:Vamei 出處:http://www.cnblogs.com/vamei