我们先来看看看几个简单的例子:
<span style="font-size:14px;">>>> for i,j in enumerate(('a','b','c')):
print i,j
0 a
1 b
2 c
>>> for i,j in enumerate([1,2,3]):
print i,j
0 1
1 2
2 3
>>> for i,j in enumerate({'a':1,'b':2}):
print i,j
0 a
1 b
>>> for i,j in enumerate('abc'):
print i,j
0 a
1 b
2 c</span>再看看enumerate的定义:
<span style="font-size:14px;">def enumerate(collection):
'Generates an indexed series: (0,coll[0]), (1,coll[1]) ...'
i = 0
it = iter(collection)
while 1:
yield (i, it.next())
i += 1</span>enumerate会将数组或列表组成一个索引序列。使我们再获取索引和索引内容的时候更加方便。
在cookbook里介绍,如果你要计算文件的行数,可以这样写:
count = len(open(thefilepath,'rU').readlines())
前面这种方法简单,但是可能比较慢,当文件比较大时甚至不能工作,下面这种循环读取的方法更合适些:
Count = 0
For count,line in enumerate(open(thefilepath,'rU')):
<span style="white-space:pre"> </span>Pass
<span style="white-space:pre"> </span>Count += 1
本文通过实例演示了Python内置函数enumerate的用法,该函数能够为迭代器对象添加索引,便于同时获取元素及其位置。此外,还介绍了如何利用enumerate进行文件行数统计,提供了一种更高效的方法。
函数的用法&spm=1001.2101.3001.5002&articleId=50897767&d=1&t=3&u=cc9ce1d2c0da4f8aac2a35bcb59503bd)
4万+

被折叠的 条评论
为什么被折叠?



