我发现了很多关于删除数组中重复项的话题,但没有一个适合我的特定用例。我有一个二维列表,我需要从中删除重复项,但是我必须保持原始序列
mylist = [['Installation', '64%'], ['C2', '14%'], ['NA', '14%'], ['C2', '14%'], ['NA', '14%'], ['na', '7%']]
我需要简单地删除重复项而不重新排列,所以..
newlist = [['Installation', '64%'], ['C2', '14%'], ['NA', '14%'], ['na', '7%']]
感谢任何帮助
最佳答案
使用 set
跟踪看到的项目:
>>> mylist = [['Installation', '64%'], ['C2', '14%'], ['NA', '14%'], ['C2', '14%'], ['NA', '14%'], ['na', '7%']]
>>> seen = set()
>>> newlist = []
>>> for item in mylist:
... t = tuple(item)
... if t not in seen:
... newlist.append(item)
... seen.add(t)
...
>>> newlist
[['Installation', '64%'], ['C2', '14%'], ['NA', '14%'], ['na', '7%']]
注意
您需要将列表转换为元组(列表不可散列);无法添加要设置的列表。
>>> seen = set()
>>> seen.add([1,2])
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unhashable type: 'list'
>>> seen.add(tuple([1,2]))
>>>
关于python - 在保持序列的同时删除二维数组中的重复项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21065347/