wutao1935

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

enumerate函数

enumerate()说明:


enumerate()是python的内置函数
enumerate在字典上是枚举、列举的意思
对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值
enumerate多用于在for循环中得到计数
例如对于一个seq,得到:

(0, seq[0]), (1, seq[1]), (2, seq[2])
1
enumerate()返回的是一个enumerate对象,例如:

 

enumerate()使用
如果对一个列表,既要遍历索引又要遍历元素时,首先可以这样写:

1 list1 = ["", "", "一个", "测试"]
2 for i in range (len(list1)):
3 print i ,list1[i]

 



上述方法有些累赘,利用enumerate()会更加直接和优美:

1 list1 = ["", "", "一个", "测试"]
2 for index, item in enumerate(list1):
3 print index, item
4 >>>
5 0 这
6 17 2 一个
8 3 测试

 


enumerate还可以接收第二个参数,用于指定索引起始值,如:

1 list1 = ["", "", "一个", "测试"]
2 for index, item in enumerate(list1, 1):
3 print index, item
4 >>>
1 这
2 是
3 一个
4 测试




补充
如果要统计文件的行数,可以这样写:

1 count = len(open(filepath, 'r').readlines())

 


1
这种方法简单,但是可能比较慢,当文件比较大时甚至不能工作。

可以利用enumerate():

1 count = 0
2 for index, line in enumerate(open(filepath,'r')): 
3 count += 1

 


---------------------
作者:竹聿Simon
来源:CSDN
原文:https://blog.csdn.net/churximi/article/details/51648388
版权声明:本文为博主原创文章,转载请附上博文链接!

posted on   逐风浪子  阅读(10421)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
点击右上角即可分享
微信分享提示