如何删除包含不同顺序元素的重复列表?

假设我有列表[[1,2,3],[4,5,6],[3,2,1]],列表的第一个和最后一个元素(也是列表)实际上是相同的 – 它们包含相同的数字集,只是顺序不同.如果我想创建一个接收列表列表的函数,并删除那些重复的列表元素(在这种情况下,删除[1,2,3]或[3,2,1]并保留剩余的一个),我怎么做?

谢谢

解决方法:

使用集合和冻结集.

设置仅存储唯一项目,它们是无序的.

>>> {3, 1, 2} == {2, 1, 3}
True

但它们只能存储不可变项目,所以我们也需要一个冷冻集.

>>> {set([1, 2, 3])}
Traceback (most recent call last):
  File "<ipython-input-16-ddc0311520e7>", line 1, in <module>
    {set([1, 2, 3])}
TypeError: unhashable type: 'set'

>>> {frozenset([1, 2, 3])}
set([frozenset([1, 2, 3])])

演示:

>>> lst = [[1,2,3],[4,5,6],[3,2,1]]
>>> seen = set()
>>> [x for x in lst if frozenset(x) not in seen and not seen.add(frozenset(x))]
[[1, 2, 3], [4, 5, 6]]
上一篇:如何在列表Python中查找重复值


下一篇:php – 为什么fputcsv会产生重复的列?