python 列表(list)去除重复的元素总结

方法一:

  将list作为set的构造函数构造一个set,然后再将set转换会list就可以

1
2
3
4
5
6
>>> myList = [1, 2, 3, 3, 2, 2, 4, 5, 5]
>>> myList
[1, 2, 3, 3, 2, 2, 4, 5, 5]
>>> myList = list(set(myList))
>>> myList
[1, 2, 3, 4, 5]

 

方法二:使用列表推导,只保留元素个数等于1

1
2
3
例如:<br>a = ['a', 'b', 'c', 'd', 'a', 'a']
b = [x for x in a if a.count(x) == 1]
print b

   不过还可以使用下面的方法,只是上面的方法更简单

1
2
3
4
5
b = []
for x in a:
  if a.count(x) == 1:
      b.append(x)
print b

 

方法三:使用字典中的fromkeys方法

  

1
2
3
a = ['b','c','d','b','c','a','a']
b = {}.fromkeys(a).keys()
print b

 方法四:用list类的sort方法

1
2
3
4
5
6
7
8
9
a = ['b','c','d','b','c','a','a']
b = list(set(a))
b.sort(key=a.index)
print b
 
不过,也可以这样写
a = ['b','c','d','b','c','a','a']
b = sorted(set(a),key=a.index)
print b

 

方法五:使用用遍历

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
l1 = ['b','c','d','b','c','a','a']
l2 = []
for i in l1:
if not i in l2:
        l2.append(i)
print l2
 
上面的代码也可以这样写
 
l1 = ['b','c','d','b','c','a','a']
l2 = []
[l2.append(i) for i in l1 if not i in l2]
print l2
 
这样就可以保证排序不变了:
 
['b', 'c', 'd', 'a']

 

方法六:使用lambda方法

1
2
3
>>> lst = [1, 2, 4, 5, 5, 5, 4, 7]
>>> print filter(lambda x: lst.count(x)<2, lst)
[1, 2, 7]

 

posted @   淋哥  阅读(18014)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示