在python中,迭代是獲取元素本身,而非元素索引,那么,假如針對有序集合,想要獲得元素索引,怎么辦呢?
方法是,使用enumerate()函數(shù):
例如:['a','b','c','d'],求輸出結(jié)果為:
0:a
1:b
2:c
3:d
此時(shí)可以使用enumerate()函數(shù),實(shí)際上enumerate()函數(shù)將該list變成了類似:
[(0,'a'),(1,'b'),(2,'c'),(3,'d')]
因此,迭代的實(shí)際是一個(gè)tuple
L=['a','b','c','d']
for x in enumerate(L):
index =x[0]
name = x[1]
print(index,':',name)
執(zhí)行結(jié)果:
0 : a
1 : b
2 : c
3 : d
如果我們知道每個(gè)tuple包含兩個(gè)元素,可以進(jìn)一步簡寫為:
for index,name in enumerate(L):
print(index,':',name)
拓展
以上例題,可以用另外一種方法實(shí)現(xiàn)
思路:利用zip()和range()結(jié)合實(shí)現(xiàn)
已知:zip()可將兩個(gè)list變成一個(gè),如:zip([0,1,2,3],['A','B','C','D']),輸出結(jié)果為:[(0,'A'),(1,'B'),(2,'C'),(3,'D')]
L = ['a', 'b', 'c', 'd']
for index, name in zip(range(1,5),L):
print index, ':', name
輸出結(jié)果:
1 : a
2 : b
3 : c
4 : d