本文研究的主要是Python enumerate索引迭代的问题,具体介绍如下。
索引迭代
Python中,迭代永远是取出元素本身,而非元素的索引。
对于有序集合,元素确实是有索引的。有的时候,我们确实想在 for 循环中拿到索引,怎么办?
方法是使用 enumerate() 函数:
1
2
3
4
5
6
7
8
|
>>> L = [ 'Adam' , 'Lisa' , 'Bart' , 'Paul' ]
>>> for index, name in enumerate (L):
... print index, '-' , name
...
0 - Adam
1 - Lisa
2 - Bart
3 - Paul
|
使用 enumerate() 函数,我们可以在for循环中同时绑定索引index和元素name。但是,这不是 enumerate() 的特殊语法。实际上,enumerate() 函数把:
1
|
[ 'Adam' , 'Lisa' , 'Bart' , 'Paul' ]
|
变成了类似:
1
|
[( 0 , 'Adam' ), ( 1 , 'Lisa' ), ( 2 , 'Bart' ), ( 3 , 'Paul' )]
|
因此,迭代的每一个元素实际上是一个tuple:
1
2
3
4
|
for t in enumerate (L):
index = t[ 0 ]
name = t[ 1 ]
print index, '-' , name
|
如果我们知道每个tuple元素都包含两个元素,for循环又可以进一步简写为:
1
2
|
for index, name in enumerate (L):
print index, '-' , name
|
这样不但代码更简单,而且还少了两条赋值语句。
可见,索引迭代也不是真的按索引访问,而是由 enumerate() 函数自动把每个元素变成 (index, element) 这样的tuple,再迭代,就同时获得了索引和元素本身。
总结
以上就是本文关于Python enumerate索引迭代代码解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:http://www.cnblogs.com/xiaoit/p/4047948.html