国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

對python中l(wèi)ist的五種查找方法說明

瀏覽:3日期:2022-07-17 16:47:49

Python中是有查找功能的,五種方式:in、not in、count、index,find 前兩種方法是保留字,后兩種方式是列表的方法。

下面以a_list = [’a’,’b’,’c’,’hello’],為例作介紹:

對python中l(wèi)ist的五種查找方法說明

string類型的話可用find方法去查找字符串位置:

a_list.find(’a’)

如果找到則返回第一個匹配的位置,如果沒找到則返回-1,而如果通過index方法去查找的話,沒找到的話會報錯。

對python中l(wèi)ist的五種查找方法說明

補充知識:Python中查找包含它的列表元素的索引,index報錯!!!

對于列表['foo', 'bar', 'baz']和列表中的項目'bar',如何在Python中獲取其索引(1)?

一、index

>>> ['foo', 'bar', 'baz'].index('bar')

警告如下

請注意,雖然這也許是回答這個問題最徹底的方法是問,index是一個相當薄弱的組件listAPI,而我不記得我最后一次使用它的憤怒。在評論中已經(jīng)向我指出,因為這個答案被大量引用,所以應(yīng)該更加完整。關(guān)于list.index跟隨的一些警告。最初可能需要查看文檔字符串:

>>> print(list.index.__doc__)L.index(value, [start, [stop]]) -> integer -- return first index of value.Raises ValueError if the value is not present.

我曾經(jīng)使用過的大多數(shù)地方index,我現(xiàn)在使用列表推導(dǎo)或生成器表達式,因為它們更具有推廣性。因此,如果您正在考慮使用index,請查看這些出色的python功能。

如果元素不在列表中,則拋出

如果項目不存在則調(diào)用index結(jié)果ValueError。

>>> [1, 1].index(2)Traceback (most recent call last): File '<stdin>', line 1, in <module>ValueError: 2 is not in list

如果該項目可能不在列表中,您應(yīng)該

首先檢查它item in my_list(干凈,可讀的方法),或

將index呼叫包裹在try/except捕獲的塊中ValueError(可能更快,至少當搜索列表很長時,該項通常存在。)

二、enumerate()

大多數(shù)答案解釋了如何查找單個索引,但如果項目在列表中多次,則它們的方法不會返回多個索引。用途enumerate():

for i, j in enumerate([’foo’, ’bar’, ’baz’]): if j == ’bar’: print(i)

該index()函數(shù)僅返回第一個匹配項,同時enumerate()返回所有匹配項。

作為列表理解:

[i for i, j in enumerate([’foo’, ’bar’, ’baz’]) if j == ’bar’]

這里還有另一個小解決方案itertools.count()(與枚舉幾乎相同):

from itertools import izip as zip, count # izip for maximum efficiency

[i for i, j in zip(count(), [’foo’, ’bar’, ’baz’]) if j == ’bar’]

對于較大的列表,這比使用更有效enumerate():

$ python -m timeit -s 'from itertools import izip as zip, count' '[i for i, j in zip(count(), [’foo’, ’bar’, ’baz’]*500) if j == ’bar’]'10000 loops, best of 3: 174 usec per loop$ python -m timeit '[i for i, j in enumerate([’foo’, ’bar’, ’baz’]*500) if j == ’bar’]'10000 loops, best of 3: 196 usec per loop

三、NumPy

如果您想要所有索引,那么您可以使用NumPy:

import numpy as np array = [1, 2, 1, 3, 4, 5, 1]item = 1np_array = np.array(array)item_index = np.where(np_array==item)print item_index# Out: (array([0, 2, 6], dtype=int64),)

它是清晰易讀的解決方案。

四、zip

具有該zip功能的所有索引:

get_indexes = lambda x, xs: [i for (y, i) in zip(xs, range(len(xs))) if x == y] print get_indexes(2, [1, 2, 3, 4, 5, 6, 3, 2, 3, 2])print get_indexes(’f’, ’xsfhhttytffsafweef’)

以上這篇對python中l(wèi)ist的五種查找方法說明就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 国产精品九九视频 | 日本一区二区三区国产 | 免费老外的毛片清高 | 99久免费精品视频在线观看2 | 亚洲欧美日韩国产精品影院 | 日韩美女免费线视频 | 久草热久草视频 | 成年人免费在线视频网站 | 国产成人精品无缓存在线播放 | 18岁免费网站 | 亚洲成a v人片在线观看 | 日本在线观看网址 | 日韩在线 中文字幕 | 美国免费毛片 | 国产成人www免费人成看片 | 成人老司机深夜福利久久 | 窝窝午夜精品一区二区 | 一二三中文乱码亚洲乱码 | 成人免费观看网欧美片 | 午夜爽爽爽 | 国产三级在线观看免费 | 99精品免费久久久久久久久日本 | 成人欧美视频在线观看播放 | 九九九热视频 | 91福利精品老师国产自产在线 | 亚洲国产精品一区二区久 | 国产成人精品aaaa视频一区 | 国产极品喷水视频jk制服 | 欧美大尺度免费一级特黄 | 欧美日中文字幕 | 在线观看国产精品入口 | 免费一级毛片不卡在线播放 | 国产欧美久久久精品 | 色偷偷成人 | 亚洲国产影视 | 欧美在线一二三区 | 日韩精品无码一区二区三区 | 欧美一级特黄aa大片视频 | 久久精品国产精品亚洲 | 久久国产精品免费网站 | 999久久久 |