Python 統(tǒng)計列表中重復(fù)元素的個數(shù)并返回其索引值的實現(xiàn)方法
需求:統(tǒng)計列表list1中元素3的個數(shù),并返回每個元素的索引
list1 = [3, 3, 8, 9, 2, 10, 6, 2, 8, 3, 4, 5, 5, 4, 1, 5, 9, 7, 10, 2]
在實際工程中,可能會遇到以上需求,統(tǒng)計元素個數(shù)使用list.count()方法即可,不做多余說明
返回每個元素的索引需要做一些轉(zhuǎn)換,簡單整理了幾個實現(xiàn)方法
1 list.index()方法
list.index()方法返回列表中首個元素的索引,當(dāng)有重復(fù)元素時,可以通過更改index()方法__start參數(shù)來更改起始索引
找到一個元素后,將起始索引替換為該元素的下一個索引,繼續(xù)進(jìn)行查找,直到找到所有的元素索引
list1 = [3, 3, 8, 9, 2, 10, 6, 2, 8, 3, 4, 5, 5, 4, 1, 5, 9, 7, 10, 2] count = list1.count(3) index_list = [] index = -1 # 通過list.index()方法的__start參數(shù),指定起始索引 for i in range(0, count): index = list1.index(3, index + 1) index_list.append(index) print(index_list)
結(jié)果如下:
2 通過索引遍歷原列表,對每一個元素進(jìn)行判斷
通過索引遍歷原列表,對每一個元素進(jìn)行判斷,如果元素是目標(biāo)元素,則返回對應(yīng)索引值,示例如下:
list1 = [3, 3, 8, 9, 2, 10, 6, 2, 8, 3, 4, 5, 5, 4, 1, 5, 9, 7, 10, 2] list1_len = len(list1) index_list = [] for i in range(0, list1_len): if list1[i] == 3: index_list.append(i) print(index_list)
結(jié)果同上
3 enumerate()函數(shù)和列表推導(dǎo)式
使用enumerate()函數(shù)返回可解析的index-value列表,然后使用列表推導(dǎo)式,同時使用if條件過濾得到目標(biāo)值的索引,示例如下:
list1 = [3, 3, 8, 9, 2, 10, 6, 2, 8, 3, 4, 5, 5, 4, 1, 5, 9, 7, 10, 2] index_list = [a for a, b in enumerate(list1) if b == 3] print(index_list)
結(jié)果同上
各位大佬有好的實現(xiàn)方法可以在下方評論分享一下
到此這篇關(guān)于Python 統(tǒng)計列表中重復(fù)元素的個數(shù)并返回其索引值的文章就介紹到這了,更多相關(guān)Python 統(tǒng)計列表元素內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python中函數(shù)返回多個結(jié)果的實例方法
在本篇文章里小編給大家整理了一篇關(guān)于python中函數(shù)返回多個結(jié)果的實例方法,有興趣的朋友們可以學(xué)習(xí)下。2020-12-12使用Python實現(xiàn)分組數(shù)據(jù)并保存到單獨的文件中
當(dāng)處理大型數(shù)據(jù)集時,通常需要將數(shù)據(jù)分組,并將每個分組的數(shù)據(jù)保存到單獨的文件中,本文將使用 Python 中的 pandas 庫來實現(xiàn)這一目標(biāo),需要的可以參考下2024-04-04詳解pandas中利用DataFrame對象的.loc[]、.iloc[]方法抽取數(shù)據(jù)
這篇文章主要介紹了pandas中利用DataFrame對象的.loc[]、.iloc[]方法抽取數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12僅用500行Python代碼實現(xiàn)一個英文解析器的教程
這篇文章主要介紹了僅用500行Python代碼實現(xiàn)一個英文解析器的教程,自然語言處理近來也是業(yè)界中一個熱門課題,作者為NLP方向的開發(fā)者,需要的朋友可以參考下2015-04-04Python使用cookielib模塊操作cookie的實例教程
cookielib模塊經(jīng)常被用來和urllib等模塊配合來制作爬蟲或者第三方SNS客戶端等程序,比如這里我們就將舉一個使用cookie來發(fā)送登錄信息登錄人人網(wǎng)的例子,well,一起來看一下Python使用cookielib模塊操作cookie的實例教程2016-07-07淺談Python中的函數(shù)(def)及參數(shù)傳遞操作
這篇文章主要介紹了淺談Python中的函數(shù)(def)及參數(shù)傳遞操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05pandas factorize實現(xiàn)將字符串特征轉(zhuǎn)化為數(shù)字特征
今天小編就為大家分享一篇pandas factorize實現(xiàn)將字符串特征轉(zhuǎn)化為數(shù)字特征,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12