Python 統計列表中重復元素的個數並返回其索引值的實現方法
需求:統計列表list1中元素3的個數,並返回每個元素的索引
list1 = [3, 3, 8, 9, 2, 10, 6, 2, 8, 3, 4, 5, 5, 4, 1, 5, 9, 7, 10, 2]
在實際工程中,可能會遇到以上需求,統計元素個數使用list.count()方法即可,不做多餘說明
返回每個元素的索引需要做一些轉換,簡單整理瞭幾個實現方法
1 list.index()方法
list.index()方法返回列表中首個元素的索引,當有重復元素時,可以通過更改index()方法__start參數來更改起始索引
找到一個元素後,將起始索引替換為該元素的下一個索引,繼續進行查找,直到找到所有的元素索引
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參數,指定起始索引 for i in range(0, count): index = list1.index(3, index + 1) index_list.append(index) print(index_list)
結果如下:
2 通過索引遍歷原列表,對每一個元素進行判斷
通過索引遍歷原列表,對每一個元素進行判斷,如果元素是目標元素,則返回對應索引值,示例如下:
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)
結果同上
3 enumerate()函數和列表推導式
使用enumerate()函數返回可解析的index-value列表,然後使用列表推導式,同時使用if條件過濾得到目標值的索引,示例如下:
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)
結果同上
各位大佬有好的實現方法可以在下方評論分享一下
到此這篇關於Python 統計列表中重復元素的個數並返回其索引值的文章就介紹到這瞭,更多相關Python 統計列表元素內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Python中的枚舉函數enumerate()的具體用法
- Python enumerate()計數器簡化循環
- Python 列表的基本操作介紹
- Python 循環函數詳細介紹
- python基礎入門之列表(一)