通常的方法是将dict锁定为您想通过其进行重复数据删除的方式,例如:
>>> a = [(0, 13, 'order1'), (14, 27, 'order2'), (14, 27, 'order2.1'), (0, 13, 'order1'), (28, 41, 'order3')]
>>> print(*{tup[:2]: tup for tup in a}.values())
(0, 13, 'order1') (14, 27, 'order2.1') (28, 41, 'order3')
这是 O(n) 时间复杂度,优于基于 O(n log n) groupby的方法。