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)
結果如下:
通過索引遍歷原列表,對每一個元素進行判斷,如果元素是目標元素,則返回對應索引值,示例如下:
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 統計列表元素內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. 怎樣才能用js生成xmldom對象,并且在firefox中也實現xml數據島?2. 基于javaweb+jsp實現企業車輛管理系統3. ASP.Net MVC利用NPOI導入導出Excel的示例代碼4. 利用ajax+php實現商品價格計算5. jstl 字符串處理函數6. JSP動態網頁開發原理詳解7. .Net core Blazor+自定義日志提供器實現實時日志查看器的原理解析8. PHP中為什么使用file_get_contents("php://input")接收微信通知9. IOS蘋果AppStore內購付款的服務器端php驗證方法(使用thinkphp)10. XML CDATA是什么?
