用python代码删除list里面的重复元素(保证元素顺序不变)
例如:a = [10,4,7,2,13,5,4,3,7,10]
方法1:集合去重,sort方法排序
指定排序关键字,按原列表中下标对应的元素的顺序进行排序,从而保证去重后元素顺序保持不变
b = list(set(a))
b.sort(key=a.index) # 指定按a列表中下标对应的元素的顺序进行排序,从而保证去重后元素顺序保持不变
print(b)
方法2:集合去重,sorted函数排序
使用sorted函数排序,返回值是一个列表,所以此处的集合set(a)不需要再次手动转换成list
# 使用sorted函数排序,返回值是一个列表,所以此处的集合set(a)不需要再次手动转换成list
b = sorted(set(a), key=a.index)
print(b)
方法3:for循环遍历(借助另外一个列表)
b = [] # 用来保存去重后的元素
for value in a:
if value not in b:
b.append(value)
print(b)
方法4:利用字典键的唯一性去重
fromkeys()方法的语法为:
dict.fromkeys(seq[, value])
说明:字典的fromkeys()方法用于创建一个新字典,以序列seq中元素做字典的键,value为字典所有键对应的初始值,默认为None。
b = {}
b = b.fromkeys(a) # dict.fromkeys(seq[, value])用于创建一个新字典,value默认为None
c = [value for value in b.keys()]
print(c)