enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。
Python 2.3. 以上版本可用,2.6 添加 start 参数。
以下是 enumerate() 方法的语法:
enumerate(sequence, [start=0])
sequence – 一个序列、迭代器或其他支持迭代对象。
start – 下标起始位置。
返回 enumerate(枚举) 对象。
>>>seasons = ['Spring', 'Summer', 'Fall', 'Winter']
>>> list(enumerate(seasons))
[(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')]
>>> list(enumerate(seasons, start=1)) # 下标从 1 开始
[(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')]
1、enumerate()是python的内置函数
2、enumerate在字典上是枚举、列举的意思
3、对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值
4、enumerate多用于在for循环中得到计数
5、例如对于一个seq,得到:
(0, seq[0]), (1, seq[1]), (2, seq[2])
# (索引值_0,value_1),(索引值_1,value_2),(索引值_2,value_3)
场景:如果对一个列表,既要遍历索引又要遍历元素时
# 方法一:
list1 = ["这", "是", "一个", "测试"]
for i in range (len(list1)):
print(i ,list1[i])
运行结果:
0 这
1 是
2 一个
3 测试
# 方法二:
list1 = ["这", "是", "一个", "测试"]
for index, item in enumerate(list1):
print (index, item)
运行结果:
0 这
1 是
2 一个
3 测试
list1 = ["这", "是", "一个", "测试"]
for index, item in enumerate(list1, 1):
print index, item
运行结果:
1 这
2 是
3 一个
4 测试
count = len(open(filepath, 'r').readlines())
注意:这种方法简单,但是可能比较慢,当文件比较大时甚至不能工作。
count = 0
for index, line in enumerate(open(filepath,'r')):
count += 1