循环处理

作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明。谢谢!(此处非原文,作为摘抄)

range():

在Python中,for循环后的in跟随一个序列的话,循环每次使用的序列元素,而不是序列的下标。

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


#执行结果:
a
c
e
g
i
k

在该例子中,我们利用len()函数和range()函数,用i作为S序列的下标来控制循环。在range函数中,分别定义上限,下限和每次循环的步长。

enumerate():

利用enumerate()函数,可以在每次循环中同时得到下标和元素:

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

#执行结果:
0 a
1 b
2 c
3 d
4 e
5 f
6 g
7 h
8 i
9 j
10 k

实际上,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)


#执行结果:
1 9 a
2 8 b
3 7 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)


#执行结果:
<zip object at 0x0000006C7FB35988>
(1, 2, 3) (9, 8, 7)
原文地址:https://www.cnblogs.com/Guido-admirers/p/6163320.html