對(duì)python中l(wèi)ist的五種查找方法說(shuō)明
Python中是有查找功能的,五種方式:in、not in、count、index,find 前兩種方法是保留字,后兩種方式是列表的方法。
下面以a_list = ['a','b','c','hello'],為例作介紹:
string類(lèi)型的話(huà)可用find方法去查找字符串位置:
a_list.find('a')
如果找到則返回第一個(gè)匹配的位置,如果沒(méi)找到則返回-1,而如果通過(guò)index方法去查找的話(huà),沒(méi)找到的話(huà)會(huì)報(bào)錯(cuò)。
補(bǔ)充知識(shí):Python中查找包含它的列表元素的索引,index報(bào)錯(cuò)!??!
對(duì)于列表["foo", "bar", "baz"]和列表中的項(xiàng)目"bar",如何在Python中獲取其索引(1)?
一、index
>>> ["foo", "bar", "baz"].index("bar")
警告如下
請(qǐng)注意,雖然這也許是回答這個(gè)問(wèn)題最徹底的方法是問(wèn),index是一個(gè)相當(dāng)薄弱的組件listAPI,而我不記得我最后一次使用它的憤怒。在評(píng)論中已經(jīng)向我指出,因?yàn)檫@個(gè)答案被大量引用,所以應(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)使用過(guò)的大多數(shù)地方index,我現(xiàn)在使用列表推導(dǎo)或生成器表達(dá)式,因?yàn)樗鼈兏哂型茝V性。因此,如果您正在考慮使用index,請(qǐng)查看這些出色的python功能。
如果元素不在列表中,則拋出
如果項(xiàng)目不存在則調(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
如果該項(xiàng)目可能不在列表中,您應(yīng)該
首先檢查它item in my_list(干凈,可讀的方法),或
將index呼叫包裹在try/except捕獲的塊中ValueError(可能更快,至少當(dāng)搜索列表很長(zhǎng)時(shí),該項(xiàng)通常存在。)
大多數(shù)答案解釋了如何查找單個(gè)索引,但如果項(xiàng)目在列表中多次,則它們的方法不會(huì)返回多個(gè)索引。用途enumerate():
for i, j in enumerate(['foo', 'bar', 'baz']): if j == 'bar': print(i)
該index()函數(shù)僅返回第一個(gè)匹配項(xiàng),同時(shí)enumerate()返回所有匹配項(xiàng)。
作為列表理解:
[i for i, j in enumerate(['foo', 'bar', 'baz']) if j == 'bar']
這里還有另一個(gè)小解決方案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']
對(duì)于較大的列表,這比使用更有效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 = 1 np_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')
以上這篇對(duì)python中l(wèi)ist的五種查找方法說(shuō)明就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
PPOCRLabel標(biāo)注的txt格式如何轉(zhuǎn)換成labelme能修改的json格式
這篇文章主要介紹了PPOCRLabel標(biāo)注的txt格式如何轉(zhuǎn)換成labelme能修改的json格式問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Python文件讀取read()?readline()?readlines()函數(shù)使用場(chǎng)景技巧示例
這篇文章主要介紹了Python文件讀取read() readline()及readlines()函數(shù)使用場(chǎng)景技巧示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08Python控制windows系統(tǒng)音量實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了Python控制windows系統(tǒng)音量實(shí)現(xiàn)實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-01-01關(guān)于pandas-profiling的降級(jí)之旅
這篇文章主要介紹了關(guān)于pandas-profiling的降級(jí)之旅,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11Python從入門(mén)到實(shí)戰(zhàn)之?dāng)?shù)據(jù)結(jié)構(gòu)篇
數(shù)據(jù)結(jié)構(gòu)中有很多樹(shù)的結(jié)構(gòu),其中包括二叉樹(shù)、二叉搜索樹(shù)、2-3樹(shù)、紅黑樹(shù)等等。本文中對(duì)數(shù)據(jù)結(jié)構(gòu)進(jìn)行了總結(jié),不求嚴(yán)格精準(zhǔn),但求簡(jiǎn)單易懂2021-11-11python實(shí)現(xiàn)基本進(jìn)制轉(zhuǎn)換的方法
這篇文章主要介紹了python實(shí)現(xiàn)基本進(jìn)制轉(zhuǎn)換的方法,涉及Python數(shù)學(xué)運(yùn)算的取余與字符串操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07