从 Python 列表中仅检索非重复元素的最佳选择是什么?假设我有以下列表:
lst = [1, 2, 3, 2, 3, 4]
我想检索以下内容:
lst = [1, 4]
(2
并且3
在该列表中不是唯一的,因此不会被检索到)
用于collections.Counter
获取项目计数。结合列表理解,只保留计数为 1 的那些。
>>> from collections import Counter
>>> lst = [1, 2, 3, 2, 3, 4]
>>> [item for item, count in Counter(lst).items() if count == 1]
[1, 4]
列表理解轻而易举:
>>> lst = [1, 2, 3, 2, 3, 4]
>>> [x for x in lst if lst.count(x) == 1]
[1, 4]
>>>
另外,我建议您不要命名变量——它会list
掩盖内置变量。