Python 中的 enumerate() 函数——for循环遍历的数据对象——同时获得索引和值

Python 的 enumerate() 函数

描述

1、enumerate是Python的一个内置函数。
2、enumerate意为:枚举,列举
3、enumerate() 函数用于将一个(可迭代的对象)可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标。也就是说,对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值。

使用场景

1、一般用在 for 循环当中,遍历或查找对象及其索引值(下标)。
2、Python 2.3. 以上版本可用,2.6 添加 start 参数。

语法

enumerate() 方法的语法:
enumerate(sequence,[startindex=0])

参数

sequence – 一个序列、迭代器或其他支持迭代对象。
start – 下标起始位置。索引值默认从0计算,可变。

返回值

返回 enumerate(枚举) 对象。

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

实例——遍历 列表

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

season=['a','b','c','d']
print(enumerate(season))

输出结果:
<enumerate object at 0x000002CE4C2EC870>

首先来看第一个print,print(enumerate(season)),
返回的结果是<enumerate object at 0x000002CE4C2EC870>
这时返回的是一个内存序列值,说明这个序列在内存中的指向是‘0x000002CE4C2EC870’。
但似乎好像不怎么像,是吧,下面例子会告诉我们,enumerate返回的的确是一个序列。

season=['a','b','c','d']
print(list(enumerate(season)))

输出结果:
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]

第二个print,print(list(enumerate(season))),返回的结果是 [(0, ‘a’), (1, ‘b’), (2, ‘c’), (3, ‘d’)]
这时返回的是一组序列,而且我们可以很确定的说,这是一个列表对象,因为用list关键字。
但还是不怎么像,的确,我们不接受忽悠,只接受赤裸裸的现实,请往下看。

season=['a','b','c','d']
for i in enumerate(season):
    print(i)

输出结果:
(0, 'a')
(1, 'b')
(2, 'c')
(3, 'd')

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

season=['a','b','c','d']
for i,element in enumerate(season):
    print(i,season[i])  //print(i,element)

输出结果:
0 a
1 b
2 c
3 d

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

season=['a','b','c','d']
for i,element in enumerate(season):
	print(i)
    
输出结果为:
0
1
2
3

这次是双变量,从返回的结果上看,第一个变量为index下标,

实例——遍历 元组

season=('a','b','c','d')
print(list(enumerate(season)))

输出结果
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]
season=('a','b','c','d')
for i in enumerate(season):
    print(i)
    
输出结果:
(0, 'a')
(1, 'b')
(2, 'c')
(3, 'd')
for i,j in enumerate(('a','b','c','d')):
    print(i,j)

输出结果:
0 a
1 b
2 c
3 d

让我们提高一个档次,将多个元组合并到一个列表中……我们要枚举此元组列表。一种做法的代码如下

letters = [('a', 'A'), ('b', 'B'), ('c', 'C')]
for index, value in enumerate(letters):
    print(index,value)
    
输出结果:
0 ('a', 'A')
1 ('b', 'B')
2 ('c', 'C')
letters = [('a', 'A'), ('b', 'B'), ('c', 'C')]
for index, value in enumerate(letters):
    lowercase = value[0]
    uppercase = value[1]
    print(f"Index '{index}' refers to the letters '{lowercase}' and '{uppercase}'")
    
输出结果:
Index '0' refers to the letters 'a' and 'A'
Index '1' refers to the letters 'b' and 'B'
Index '2' refers to the letters 'c' and 'C'

实例——遍历 字符串

对可遍历的对象均可用enumerate,这其中也包括字符串!请看:

abc='abcd'
print(enumerate(abc))

输出结果
<enumerate object at 0x000001B75A712828>
abc='abcdefg'
print(list(enumerate(abc)))

输出结果:
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]
abc='abcdefg'
for i in enumerate(abc):
    print(i)

输出结果:
(0, 'a')
(1, 'b')
(2, 'c')
(3, 'd')
abc='abcdefg'
for i,element in enumerate(abc):
    print(i,abc[i])

输出结果:
0 a
1 b
2 c
3 d    

用enumerate()让循环更加Python化

修改起始索引

另一个有用的特性是,enumerate()函数允许我们为循环自定义起始索引值。
enumerate()函数中接受一个可选参数,该参数允许你为本次循环中的计数器变量设置初始值:

names = ["Alice","Bob","Carl"]
for index,value in enumerate(names,1):
    print(f'{index}: {value}')

在上面的例子中,我将函数调用改为enumerate(names, 1),后面的参数1就是本次循环的起始索引,替换默认的0:

1: Alice
2: Bob
3: Carl

OK,这段代码演示的就是如何将Python的enumerate()函数默认0起始索引值修改为1(或者其他任何整形值,根据需求去设置不同值)

enumerate()背后是如何工作的

他通过Python迭代器来实现的。
意思就是每个元素的索引是懒加载的(一个接一个,用的时候生成),这使得内存使用量很低并且保持这个结构运行很快。

请看如下代码:

>>> names = ['Alice', 'Bob', 'Carl']
>>> enumerate(names)
<enumerate object at 0x1057f4120>

在上面这个代码片段中,正如你所见,我使用了和前面一样的示例代码。但是,调用enumerate()函数并不会立即返回循环的结果,而只是在控制台中返回了一个enumerate对象。

正如你所看到的,这是一个“枚举对象”。它的确是一个迭代器。就像我说的,它会在循环请求时懒加载地输出每个元素。

为了验证,我们可以取出那些“懒加载”的元素,我计划在这个迭代器上调用Python的内置函数list()。

>>> list(enumerate(names))
[(0, 'Alice'), (1, 'Bob'), (2, 'Carl')]

对于输入list()中的每个enumerate()迭代器元素,迭代器会返回一个形式为(index,element)的元组作为list的元素。在典型的for-in循环中,你可以利用Python的数据结构解包功能来充分利用这一点特性:

for index, element in enumerate(iterable):
    # ...
  • 18
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 您好,对于您的问题,我可以回答。对于一个 float 数组,可以通过循环遍历数组来找到最大、最小以及它们的索引。具体实现可以参考以下代码: float arr[] = {1.2, 3.4, 5.6, 7.8, 9.}; int len = sizeof(arr) / sizeof(float); float max_val = arr[]; float min_val = arr[]; int max_idx = ; int min_idx = ; for (int i = 1; i < len; i++) { if (arr[i] > max_val) { max_val = arr[i]; max_idx = i; } if (arr[i] < min_val) { min_val = arr[i]; min_idx = i; } } printf("最大为%f,索引为%d\n", max_val, max_idx); printf("最小为%f,索引为%d\n", min_val, min_idx); 希望这个回答能够帮到您。 ### 回答2: c float数组的最大、最小以及索引可以通过遍历数组获取。 最大的获取可以通过将数组的第一个元素赋给一个变量max_value,然后遍历数组,如果遍历到的元素比max_value大,则更新max_value的,直到遍历完整个数组。最后max_value就是数组的最大。 最小的获取与最大类似,可以通过将数组的第一个元素赋给一个变量min_value,然后遍历数组,如果遍历到的元素比min_value小,则更新min_value的,直到遍历完整个数组。最后min_value就是数组的最小索引的获取可以通过遍历数组,判断数组的每个元素与最大或最小是否相等,如果相等,则将该元素的索引保存到一个变量index,最后index就是数组最大或最小索引。 需要注意的是,数组的索引是从0开始的,所以最大或最小索引不一定是整数。如果有多个相同最大或最小,可以通过保存多个索引的数组或链表来记录。 ### 回答3: 对于一个float类型的数组c,可以通过以下步骤来找到数组的最大、最小以及对应的索引。 1. 初始化最大max_num和最小min_num为数组c的第一个元素c[0],索引max_index和min_index为0。 2. 从数组c的第二个元素开始遍历直到最后一个元素。 3. 在遍历的过程,比较当前元素c[i]与最大max_num和最小min_num的大小关系。 - 如果c[i]大于max_num,更新max_num为c[i],max_index为i。 - 如果c[i]小于min_num,更新min_num为c[i],min_index为i。 4. 遍历完成后,max_num和min_num即为数组c的最大、最小,max_index和min_index即为对应的索引。 以下是使用Python语言的示例代码: ```python c = [1.2, 5.4, -3.1, 2.7, 0.8] # 示例数组 max_num = c[0] min_num = c[0] max_index = 0 min_index = 0 for i in range(1, len(c)): if c[i] > max_num: max_num = c[i] max_index = i if c[i] < min_num: min_num = c[i] min_index = i print("数组的最大为", max_num) print("最大索引为", max_index) print("数组的最小为", min_num) print("最小索引为", min_index) ``` 执行以上代码将输出: ``` 数组的最大为 5.4 最大索引为 1 数组的最小为 -3.1 最小索引为 2 ``` 注意:在实际编程,可能还需要考虑数组为空的情况以及处理浮点数精度问题。以上代码仅作为示例,具体实现可能因编程语言及应用场景的不同而略有差异。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值