Python去除列表中重複元素的方法

2021-08-19 08:16:26 字數 944 閱讀 4927

比較容易記憶的是用內建的set

l1 = ['b','c','d','b','c','a','a']

l2 = list(set(l1))

print l2

還有一種據說速度更快的,沒測試過兩者的速度差別

l1 = ['b','c','d','b','c','a','a']

l2 = {}.fromkeys(l1).keys()

print l2

這兩種都有個缺點,祛除重複元素後排序變了:

['a', 'c', 'b', 'd']

如果想要保持他們原來的排序:

用list類的sort方法

l1 = ['b','c','d','b','c','a','a']

l2 = list(set(l1))

l2.sort(key=l1.index)

print l2

也可以這樣寫

l1 = ['b','c','d','b','c','a','a']

l2 = sorted(set(l1),key=l1.index)

print l2

也可以用遍歷

l1 = ['b','c','d','b','c','a','a']

l2 =

for i in l1:

if not i in l2:

print l2

上面的**也可以這樣寫

l1 = ['b','c','d','b','c','a','a']

l2 =

print l2

這樣就可以保證排序不變了:

['b', 'c', 'd', 'a']

希望本文所述對大家的python程式設計有所幫助。

python 去除列表重複元素

1.1邏輯去除 推薦面試使用 def dedup list li 定義乙個列表去重的函式 定義乙個空列表用於接收不重複的列表元素 dedup li list 定義乙個相關變數,用於下標的判斷 index 0 相同的任意個元素,用列表的index方法只能取到第乙個重複元素的下標 遍歷列表,同時每取到乙...

python 去除列表重複元素

比較容易記憶的是用內建的 setl1 b c d b c a a l2 list set l1 print l2 還有一種據說速度更快的,沒測試過兩者的速度差別 l1 b c d b c a a l2 fromkeys l1 keys print l2 這兩種都有個缺點,祛除重複元素後排序變了 a ...

PYTHON去除重複元素2

import numpy as np import pandas as pd 輸入 兩個列表 輸出 去除重複元素的列表 方法 將list轉換為array,處理之後,轉換回去!挺麻煩啊!方式1 瞎折騰 list1 1,3,5,1,7,3,1,1 list2 2,4,6,2,8,4,2,2 list3 ...