十年網站開發(fā)經驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網站問題一站解決
這篇文章給大家介紹使用Python怎么從list列表中刪除多個重復元素,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

list為例,刪除其中所有值為6的元素:
l=[9,6,5,6,6,7,8,9,6,0]
首先嘗試remove方法:
l.remove(6) print(l)
結果為:[9, 5, 6, 6, 7, 8, 9, 6, 0],只刪除了第一個為6的元素。
如果采用for循環(huán)遍歷各元素:
for x in l: if x == 6: l.remove(x)
結果為[9, 5, 7, 8, 9, 6, 0],后面的6沒有刪除。主要因為remove改變了list長度和每一個元素的位置。
采用del語句需要找到元素對應下標del l[1]。應用for循環(huán)改變下標比較混亂,所以使用while循環(huán):
length=len(l) x=0 while x < length: if l[x] == 6: # l.remove(l[x]) del l[x] x -= 1 length -= 1 x += 1
結果為[9, 5, 7, 8, 9, 0],刪除了列表中所有的6。另外將del l[x]改為l.remove(l[x])也可以。
補充:
最近發(fā)現了numpy的unique()函數可以去除列表中所有重復元素且將列表元素從小到大排序:
import numpy as np l=[9,6,5,6,6,7,8,9,6,0] a = np.unique(l) print(a)
print(a)結果為[0 5 6 7 8 9]。l和a類型不同,前者是'list',后者是'numpy.ndarray'。
關于使用Python怎么從list列表中刪除多個重復元素就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。