一、简介:
    该函数在字面上是枚举、列举的意思,用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,
  同时列出数据和数据下标,一般用在 for 循环当中,可同时得到数据对象的值及对应的索引值。如对于下面的例子:
  
  enumerate参数为可遍历/可迭代的对象(如列表、字符串)
enumerate多用于在for循环中得到计数,利用它可以同时获得索引和值,即需要index和value值的时候可以使用enumerate

enumerate()返回的是一个enumerate对象

>>> lst = [1, 2, 3, 4, 10, 5]
>>> enumerate(lst)
<enumerate object at 0x00000000032A3990>

二、 语法:
  enumerate(iterable,start)
  iterable:可迭代对象(列表、元祖、字典、迭代器、字符串等)
  stat:索引序列的起始值

注意:此内置函数常用语for循环

三、enumerate的使用:
例如:已知lst = [1,2,3,4,5,6],要求输出:
0,1
1,2
2,3
3,4
4,5
5,6

>>> lst = [1,2,3,4,5,6]
>>> for index,value in enumerate(lst):
  print ('%s,%s' % (index,value))

0,1
1,2
2,3
3,4
4,5
5,6
#指定索引从1开始
>>> lst = [1,2,3,4,5,6]
>>> for index,value in enumerate(lst,1):
print ('%s,%s' % (index,value))

1,1
2,2
3,3
4,4
5,5
6,6

#指定索引从3开始
>>> for index,value in enumerate(lst,3):
print ('%s,%s' % (index,value))

3,1
4,2
5,3
6,4
7,5
8,6

  实例2:

 1 b = ['Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sunday']
 2 for index,i in enumerate(b,1):
 3     print("星期%d:%s"%(index,i))
 4
 5 # 星期1:Monday
 6 # 星期2:Tuesday
 7 # 星期3:Wednesday
 8 # 星期4:Thursday
 9 # 星期5:Friday
10 # 星期6:Saturday
11 # 星期7:Sunday
 

补充:
如果要统计文件的行数,可以这样写:
count = len(open(filepath, 'r').readlines())
这种方法简单,但是可能比较慢,当文件比较大时甚至不能工作。

可以利用enumerate():
count = 0
for index, line in enumerate(open(filepath,'r')): 
   count += 1



01-12 23:50