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