在平时开辟过程中,常常遇到需要在数据中获取特定的元素的信息,如到达目的地最近的车站,橱窗里面最贵的物品等等。怎么办?看下面
方法一: 利用数组自身的特性 list.index(target), 其中a是你的目标list,target是你需要的下标对应的值
- li = [10,8,9,26,72,6,28]
- print(li.index(8))
复制代码 但是,如果a中有多个8呢?
我们发现,这种方法仅仅能获取都第一个匹配的value的下标(可以试试o_o)
所以,我们看看我们的第二种方案:
方法二: 利用enumerate函数。
- >>> li = [10,8,9,26,72,6,28]
- >>> print (enumerate(li))
- <enumerate object at 0x0000000002B9A990>
复制代码 原来enumerate的输出类型是enumerate object对象,所以,我们可以如下
- >>> li
- [10, 8, 9, 26, 72, 6, 28]
- >>> print(list(enumerate(li)))
- [(0, 10), (1, 8), (2, 9), (3, 26), (4, 72), (5, 6), (6, 28)]
- >>> print([i for i,j in enumerate(li) if j == 8])
- [1]
复制代码 再看,如果a中有多个‘8’呢?
- >>> li.append(8)
- >>> li.append(8)
- >>> li
- [10, 8, 9, 26, 72, 6, 28, 8, 8]
- >>> print(li.index(8))
- 1
- #学习中遇到问题没人解答?小编创建了一个Python学习交流群:531509025
- >>> print(list(enumerate(li)))
- [(0, 10), (1, 8), (2, 9), (3, 26), (4, 72), (5, 6), (6, 28), (7, 8), (8, 8)]
- >>> print([i for i,j in enumerate(li) if j == 8])
- [1, 7, 8]
复制代码 可见,list的index()方法是在list中找到第一个匹配的值。
而enumerate是将list(固然,也包含别的类型)中的元素元组化,然后我们利用循环方法获取相应的匹配的结果。所以方案二对于重复的数值能够一个不漏的get出来。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! 更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |