python 去除列表重複元素

2021-08-20 10:08:45 字數 1204 閱讀 3118

1. 1邏輯去除(推薦面試使用)

def dedup_list(li):

"""定義乙個列表去重的函式"""

# 定義乙個空列表用於接收不重複的列表元素

dedup_li = list()

# 定義乙個相關變數,用於下標的判斷

index = 0

# 相同的任意個元素,用列表的index方法只能取到第乙個重複元素的下標

# 遍歷列表,同時每取到乙個元素,相關變數加1,保持和遍歷到的元素下標值相同

# 只有當當前元素的下標值和當前元素的index取到的下標一致才能加入去重列表中

for temp in li:

if li.index(temp) == index:

index += 1

return dedup_li

li = [1, 1, 2, 3, 4, 5, 5, 6]

print(dedup_list(li))

1.2使用continue

def delete_same_item_in_list(li):

new_li = list()

for item in li:

if item not in new_li:

else:

continue

return new_li

li = [1, 2, 3, 4, 4, 5, 5, 5, 6, 7]

print(delete_same_item_in_list(li))

2. 使用集合

list(set(li))
3. 用字典

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

dedup_li = {}.fromkeys(li).keys()

print(dedup_li)

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

dedup_li = list(set(li))

dedup_li.sort(key=li.index)

print(dedup_li)

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

dedup_li =

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去除列表中重複元素的方法

比較容易記憶的是用內建的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 ...

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 ...