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]
>>> (10)
0
>>> (19)
Traceback (most recent call last):
File "<pyshell#3>", line 1, in <module>
(19)
ValueError: 19 is not in list
>>> (15)
5
2、获取列表最大值、最小值的索引:
(min(lst))
0
>>> (max(lst))
9
>>>
3、python列表中如果有重复的元素,列表的index()函数只返回第一个元素的索引:
(30)
>>> lst
[10, 11, 12, 13, 14, 15, 20, 30, 40, 50, 30]
>>> (30)
7
如果要返回所有重复元素的索引,则需要处理一把,方法比较多,下面介绍使用defaultdict方法:
from collections import defaultdict
>>>
>>> dct = defaultdict(list)
>>> dct
defaultdict(<class 'list'>, {})
>>> type(dct)
<class ''>
>>>
>>> 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]})