午夜视频在线网站,日韩视频精品在线,中文字幕精品一区二区三区在线,在线播放精品,1024你懂我懂的旧版人,欧美日韩一级黄色片,一区二区三区在线观看视频

分享

python列表常見的5種去重方法

 hzlinhui 2024-12-15

列表去重在python面試和實(shí)際運(yùn)用中,十分常見,也是最基礎(chǔ)的重點(diǎn)知識。以下總結(jié)了5種常見的列表去重方法一、使用for循環(huán)實(shí)現(xiàn)列表去重此方法去重后,原順序保持不變。# for循環(huán)實(shí)現(xiàn)列表去重list1 = ['a', 'b', 1, 3, 9, 9, 'a']list2 = []for l1 in list1:if l1 not in list2:list2.append(l1)print(lis

一位代碼 ?·? 2021-12-26 15:29:40 發(fā)布

列表去重在python實(shí)際運(yùn)用中,十分常見,也是最基礎(chǔ)的重點(diǎn)知識。
以下總結(jié)了5種常見的列表去重方法
一、使用for循環(huán)實(shí)現(xiàn)列表去重
此方法去重后,原順序保持不變。

# for循環(huán)實(shí)現(xiàn)列表去重
list1 = ['a', 'b', 1, 3, 9, 9, 'a']
list2 = []
for l1 in list1:
    if l1 not in list2:
        list2.append(l1)
print(list2)

結(jié)果:['a’, 'b’, 1, 3, 9]

二、使用列表推導(dǎo)式去重
此方法去重后,原順序保持不變。

# 使用列表推導(dǎo)式去重
list1 = ['a', 'b', 1, 3, 9, 9, 'a']
res = []
[res.append(i) for i in list1 if i not in res]
print(res)

結(jié)果:['a’, 'b’, 1, 3, 9]

三、使用集合轉(zhuǎn)換函數(shù)set()實(shí)現(xiàn)列表去重
原理:同一個集合的元素之間是不允許重復(fù)的

# set()列表去重
list1 = ['a', 'b', 1, 3, 9, 9, 'a']
list2 = list(set(list1))
print(list2)

結(jié)果:[1, 3, 9, 'b’, 'a’]
問題:使用set()函數(shù)去重后,會自動排序,則原列表的順序會發(fā)生改變
解決辦法有2種:
第一種方法,使用sort()方法

# # 第一種方法,sort()
list1 = ['a', 'b', 1, 3, 9, 9, 'a']
list2 = list(set(list1))
list2.sort(key=list1.index)
print(list2)

結(jié)果:['a’, 'b’, 1, 3, 9]
注:sort()方法沒有返回值,對列表元素進(jìn)行原地排序
第二種方法,使用sorted()函數(shù)

# 第二種方法,sored()
list1 = ['a', 'b', 1, 3, 9, 9, 'a']
list2 = sorted(list(set(list1)), key=list1.index)
print(list2)

結(jié)果:['a’, 'b’, 1, 3, 9]
注:python內(nèi)置函數(shù)sorted()函數(shù)返回新的列表,并不對原列表做任何修改

四、使用新建字典方式實(shí)現(xiàn)列表去重
原理:字典的"鍵"是不允許重復(fù)的
此方法去重后,原來順序保持不變。

# 使用新建字典實(shí)現(xiàn)列表去重
list1 = ['a', 'b', 1, 3, 9, 9, 'a']
dic = {}
dic = dic.fromkeys(list1).keys()
print(list(dic))

結(jié)果:['a’, 'b’, 1, 3, 9]

五、刪除列表中存在重復(fù)的數(shù)據(jù)
上面的4種去重方法,都是保留一個,刪除其他
下面這種方法則是,只要存在重復(fù),一個都不保留

# 刪除存在重復(fù)的值,不保留
list1 = ['a', 'b', 1, 3, 9, 9, 'a']
list2 = [i for i in list1 if list1.count(i) == 1]
print(list2)

結(jié)果:['b’, 1, 3]

以上就是關(guān)于列表去重的5種方法,可以根據(jù)需求選擇對應(yīng)的方法。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多