1、python列表的index()函数返回元素的索引,如果元素不存在,则引发ValueError。

lst = [10, 11, 12, 13, 14, 15, 20, 30, 40, 50]
>>> lst
[10, 11, 12, 13, 14, 15, 20, 30, 40, 50]
>>> lst.index(10)
0
>>> lst.index(19)
Traceback (most recent call last):
  File "<pyshell#3>", line 1, in <module>
    lst.index(19)
ValueError: 19 is not in list
>>> lst.index(15)
5

    2、获取列表最大值、最小值的索引:

lst.index(min(lst))
0
>>> lst.index(max(lst))
9
>>> 

    3、python列表中如果有重复的元素,列表的index()函数只返回第一个元素的索引:

lst.append(30)
>>> lst
[10, 11, 12, 13, 14, 15, 20, 30, 40, 50, 30]
>>> lst.index(30)
7

    如果要返回所有重复元素的索引,则需要处理一把,方法比较多,下面介绍使用defaultdict方法:

from collections import defaultdict
>>> 
>>> dct = defaultdict(list)
>>> dct
defaultdict(<class 'list'>, {})
>>> type(dct)
<class 'collections.defaultdict'>
>>> 
>>> for key, value in [(v, i) for i, v in enumerate(lst)]:
	dct[key].append(value)

	
>>> dct
defaultdict(<class 'list'>, {10: [0], 11: [1], 12: [2], 13: [3], 14: [4], 15: [5], 20: [6], 30: [7, 10], 40: [8], 50: [9]})

 

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐