enumerate() 函数的简单介绍
enumerate() 函数的概念:
- enumerate() 函数:用于将一个可迭代的数据对象(如列表 、元组或字符串)组合为一个索引序列,同时列出数据和数据下标 ,一般用在 for 循环当中。
再来看看enumerate() 函数的语法结构:
- enumerate(sequence, [start=0]),其中sequence是一个可迭代序列,start是一个可选参数 ,表示序列下标的起始位置;
关于enumerate()函数,有以下几点需要注意:
- ① enumerate()函数是Python中的内置函数,可以直接配合for循环使用;
- ② 默认情况下 ,start参数索引计数器是从零开始计数的 ,但是你可以将其设置为任意的整数;
- ③ enumerate()函数得到的是多个值,我们需要采用“序列解包”的方式,获取到每一个元素;
可迭代对象和序列解包
可迭代对象
通俗的讲:可迭代指的就是我们可以循环获取其中的每一个元素 。某对象可以使用for循环的必要条件是该对象是可迭代的。
你可能还不知道什么是可迭代对象 ,这里也不过多的去解释,你如果想深入了解它,可以自行下去查资料 ,但是这里我要讲述 “如何判断一个对象是可迭代对象 ”。
- 可以通过內置函数isinstance()来判断一个对象是否为可迭代对象 。
from collections.abc import Iterable print(isinstance("梁某人", Iterable)) # True print(isinstance([1,True,2.3],Iterable)) # True print(isinstance(1, Iterable)) # False print(isinstance(range(10), Iterable)) # True
通过上述代码演示,我们就知道哪些对象是可迭代对象,可以使用for循环 ,哪些对象不是可迭代对象,也不能使用for循环。
在Python基础中,我们还将到了一个“序列”的概念 ,其实序列也是一种可迭代对象,其中列表( list)、元组( tuple)、字符串( str)等都是序列,因此它们也都是可迭代对象 ,也就都可以配合enumerate()函数使用了。
序列解包
通俗的说:就是一次将多个变量赋值给多个值 。很简单 ,不要想的太高深,我们简单举个例子你就知道了 。
x, y = (12, 54) print(x) # 12 print(y) # 54
结果如下:
enumerate() 函数的简单使用
该函数最常就是配合for循环使用,我们就以此为例 ,为大家演示enumerate() 函数的用法。
需求:打印出班级中大于18岁的同学名字;
如果使用普通的for循环:
i = 0 name = ["张三", "李四", "王五"] lis = [13, 22, 43] for element in lis: if element >= 18: print(i, name[i], lis[i]) i += 1
结果如下:
如果for循环,配合enumerate()函数使用:
name = ["张三", "李四", "王五"] lis = [13, 22, 43] for index, value in enumerate(lis): if value >= 18: print(index, name[index], value)
结果如下:
普通for循环我也就不多说了。仔细观察for循环+enumerate()函数的搭配使用,序列使用过该函数后 ,会返回元素下标和元素组合的元组,我们采用序列解包的方式,将其赋值给了index和value ,其中index表示lis列表中每个元素的下标,value表示lis列表中每个元素的值,如下图所示:
接着再仔细观察上图 ,可以发现:enumerate()函数默认序列第一个元素的下标为0,这个也是和Python中序列的元素访问一致 。但是有时候,我们就想让第一个元素的下标变为1 ,第二个元素的下标变为2 ,怎么办呢?
从上图可以看出:enumerate()函数中有一个start参数,很好的帮我们解决了上述问题。
其实关于这个函数的用法,大家不必说要钻的多深 ,掌握它最通俗的用法就够了,相信它未来会帮助你很多。