Python刪除列表中重復(fù)元素的七種方法舉例
前言
嗨嗨,大家晚上好 ~ 又來(lái)給你們分享小妙招啦
在python列表有重復(fù)元素時(shí),可以有以下幾種方式進(jìn)行刪除
覺(jué)得不錯(cuò)的話,趕緊學(xué)起來(lái)用用吧 !
直接遍歷列表刪除
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
for el in l1:
if l1.count(el) > 1:
l1.remove(el)
print(l1)# 會(huì)漏刪,因?yàn)閯h除一個(gè)元素后,后面的元素向前補(bǔ)位,導(dǎo)致緊跟的一個(gè)元素被跳過(guò).
通過(guò)遍歷索引刪除
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
for el in range(len(l1)): # 此時(shí)len(l1)已經(jīng)確定,不會(huì)隨著l1后面的變化而變化
if l1.count(l1[el]) > 1:
l1.remove(l1[el])
print(l1) # 會(huì)報(bào)錯(cuò),因?yàn)閯h除元素后導(dǎo)致l1的長(zhǎng)度變短了,但是for遍歷的還是之前的索引長(zhǎng)度,會(huì)導(dǎo)致索引超過(guò)范圍而報(bào)錯(cuò)
通過(guò)遍歷創(chuàng)建的切片來(lái)刪除原列表
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
for el in l1[:]:
if l1.count(el) > 1:
l1.remove(el) # 沒(méi)有問(wèn)題,可以去重,但是無(wú)法保留原有的順序
print(l1)
用新列表記錄需要保留的元素
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
lst = []
for el in l1:
if lst.count(el) < 1:
lst.append(el)
print(lst) # 沒(méi)有問(wèn)題,也能保留原有順序,但是創(chuàng)建了新列表
通過(guò)索引倒著刪除
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
for el in range(len(l1)-1, -1, -1):
if l1.count(l1[el]) > 1:
l1.pop(el) # 沒(méi)有問(wèn)題,且保留原順序
# l1.remove(l1[el]) # 沒(méi)有問(wèn)題,但是不能保留原有順序
# del l1[el] # 這樣則會(huì)保留原有順序,小伙伴可以想一想為什么
print(l1)
通過(guò)遞歸函數(shù)刪除
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
def set_lst(lst):
for el in lst:
if lst.count(el) > 1:
lst.remove(el)
set_lst(lst) # 每次開(kāi)辟一個(gè)新函數(shù),判斷上次被刪除了一個(gè)元素后的列表
else: # 直到最后,列表里的元素都是一個(gè),運(yùn)行了else
return lst
print(set_lst(l1)) # 因?yàn)槭菑那懊骈_(kāi)始刪除的,所以不保留原有順序
'''
[1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 6, 5, 5, 2, 2]
[1, 3, 6, 5, 2, 2]
[1, 3, 6, 5, 2] return lst = [1, 3, 6, 5, 2]
'''
毫無(wú)疑問(wèn)set()是最方便的
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2] lst = list(set(l1)) print(lst)
總結(jié)
到此這篇關(guān)于Python刪除列表中重復(fù)元素的七種方法舉例的文章就介紹到這了,更多相關(guān)Python刪除列表重復(fù)元素內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python實(shí)現(xiàn)刪除list列表重復(fù)元素的方法總結(jié)
- Python列表刪除重復(fù)元素與圖像相似度判斷及刪除實(shí)例代碼
- python3列表刪除大量重復(fù)元素remove()方法的問(wèn)題詳解
- Python代碼實(shí)現(xiàn)刪除一個(gè)list里面重復(fù)元素的方法
- Python list列表中刪除多個(gè)重復(fù)元素操作示例
- Python實(shí)現(xiàn)連接兩個(gè)無(wú)規(guī)則列表后刪除重復(fù)元素并升序排序的方法
- Python實(shí)現(xiàn)列表刪除重復(fù)元素的三種常用方法分析
- python列表中刪除重復(fù)元素的三種方法
相關(guān)文章
基于Python實(shí)現(xiàn)的ID3決策樹(shù)功能示例
這篇文章主要介紹了基于Python實(shí)現(xiàn)的ID3決策樹(shù)功能,簡(jiǎn)單描述了ID3決策樹(shù)的相關(guān)概念,并結(jié)合實(shí)例形式分析了Python實(shí)現(xiàn)ID3決策樹(shù)的具體定義與使用技巧,需要的朋友可以參考下2018-01-01
Python學(xué)習(xí)入門(mén)之區(qū)塊鏈詳解
區(qū)塊鏈的基礎(chǔ)概念很簡(jiǎn)單:一個(gè)分布式數(shù)據(jù)庫(kù),存儲(chǔ)一個(gè)不斷加長(zhǎng)的 list,list 中包含著許多有序的記錄。下面這篇文章主要給大家介紹了關(guān)于Python學(xué)習(xí)入門(mén)之區(qū)塊鏈的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面來(lái)一起看看吧。2017-07-07
Python簡(jiǎn)單實(shí)現(xiàn)安全開(kāi)關(guān)文件的兩種方式
這篇文章主要介紹了Python簡(jiǎn)單實(shí)現(xiàn)安全開(kāi)關(guān)文件的兩種方式,涉及Python的try語(yǔ)句針對(duì)錯(cuò)誤的判定與捕捉相關(guān)技巧,需要的朋友可以參考下2016-09-09
Pytorch 多維數(shù)組運(yùn)算過(guò)程的索引處理方式
今天小編就為大家分享一篇Pytorch 多維數(shù)組運(yùn)算過(guò)程的索引處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
在pycharm中無(wú)法import所安裝的庫(kù)解決方案
這篇文章主要介紹了在pycharm中無(wú)法import所安裝的庫(kù)解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05

