谈谈python enumerate()函数的用法_python中enumerate函数的用法

描述

enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标。

也就是说,对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值。

一般用在 for 循环当中。

Python 2.3. 以上版本可用,2.6 添加 start 参数。

语法

以下是 enumerate() 方法的语法:

enumerate(sequence[,startindex=0])

参数

sequence -- 一个序列、迭代器或其他支持迭代对象。

start -- 下标起始位置。

返回值

返回 enumerate(枚举) 对象。

相信这样大家肯定看的似懂非懂,云里雾里吧,下面来看实例~

实例

season=['spring','summer','fall','winter']print(enumerate(season))print(list(enumerate(season)))for i inenumerate(season):print(i)for i,element inenumerate(season):print(i,season[i])print(i)

输出结果为:

[(0, 'spring'), (1, 'summer'), (2, 'fall'), (3, 'winter')]

(0, 'spring')

(1, 'summer')

(2, 'fall')

(3, 'winter')

0 spring

01summer1

2fall2

3winter3

4个print输出,特地也作了4个结果块:

首先来看第一个print,print(enumerate(season)),返回的结果是

这时返回的是一个内存序列值,说明这个序列在内存中的指向是‘0x000002CE4C2EC870’。但似乎好像不怎么像,是吧,下面例子会告诉我们,enumerate返回的的确是一个序列。

第二个print,print(list(enumerate(season))),返回的结果是

[(0, 'spring'), (1, 'summer'), (2, 'fall'), (3, 'winter')]

这时返回的是一组序列,而且我们可以很确定的说,这是一个列表对象,因为用list关键字。但还是不怎么像,的确,我们不接受忽悠,只接受赤裸裸的现实,请往下看。

第三个print,for i in enumerate(season): print(i),返回的结果是

(0, 'spring')

(1, 'summer')

(2, 'fall')

(3, 'winter')

这时返回的是下标与对应值的组合,默认下标从0开始,如果指定startindex,则从指定数开始。这时,我们应该可以确定了,enumerate返回值确实是一个序列。

第四个print,for i,element in enumerate(season): print(i,season[i]) print(i),返回的结果是

0 spring

0

1 summer

1

2 fall

2

3 winter

3

这次是双变量,从返回的结果上看,第一个变量为index下标,第二个是value下标对应值。

这样看貌似enumerate()函数也没什么嘛,别乱,接下来可能会刷新三观哦~

上面的例子enumerate()的对象参数是一个列表,但enumerate可不仅仅如此,文档上解释是对可遍历的对象均可用enumerate,这其中也包括字符串!请看:

abc='abcdefg'

print(enumerate(abc))print(list(enumerate(abc)))for i inenumerate(abc):print(i)for i,element inenumerate(abc):print(i,abc[i])

输出结果为

[(0,'a'), (1, 'b'), (2, 'c'), (3, 'd'), (4, 'e'), (5, 'f'), (6, 'g')]

(0,'a')

(1, 'b')

(2, 'c')

(3, 'd')

(4, 'e')

(5, 'f')

(6, 'g')

0 a1b2c3d4e5f6 g

与列表完全一样,意不意外?!

enumerate还有其他用处,我们先创建一个文本文档abd123.txt,里面借助十二生肖,每一行写一个生肖,比如“我是一只鼠”,如图所示

1097561-20170816143829381-513220737.png

现在要求把行数输出来。

第一种,直接用len()函数。

f=open('C:\\Users\Ronghere\Desktop\\abc123.txt','r')

g=f.readlines()print(len(g))

输出结果为12,正确。但如果这个数值很大的话,效率就不可观了~

第二种,用enumerate()函数。

f=open('C:\\Users\Ronghere\Desktop\\abc123.txt','r')

g=f.readlines()print(len(g))

count=0for index, line inenumerate(g):

count+= 1

print(count)

输出结果也是12,但效率比之前的要高不少。

PS,尽量不要嵌套多层函数,这样会耗资源,甚至会出错,多使用变量临时存储下来,这是一个良好的编码习惯。比如这次,本来是不想引入变量g的,但是嵌套进去后发现出错了,所以临时存储还是有必要的,而且变量用完可以del掉,避免内存消耗。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值