您好,登錄后才能下訂單哦!
這篇文章給大家介紹使用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循環遍歷各元素:
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循環改變下標比較混亂,所以使用while循環:
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])
也可以。
補充:
最近發現了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列表中刪除多個重復元素就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。