无论Python中的顺序如何,都要计算元组列表中唯一元素的数量

时间:2013-11-17 09:14:11

标签: python list set

我有一个包含以下形式的元组的列表:

[('s1', 's2'),('s3','s32')...('s2','s1')]`

考虑到顺序不重要,我如何计算不同元组的数量?

示例:('s1','s2')('s2','s1')

相同

2 个答案:

答案 0 :(得分:6)

使用collections.Counterfrozenset

>>> from collections import Counter
>>> Counter(map(frozenset, [('s1', 's2'),('s3','s32'), ('s2','s1')]))
Counter({frozenset(['s2', 's1']): 2, frozenset(['s3', 's32']): 1})

将密钥作为元组获取:

>>> c = Counter(map(frozenset, [('s1', 's2'),('s3','s32'), ('s2','s1')]))
>>> {tuple(s): count for s, count in c.most_common()}
{('s2', 's1'): 2, ('s3', 's32'): 1}

答案 1 :(得分:6)

使用frozenset规范化您的不同元组。然后检查结果集中的项目数量:

>>> l = [('s1', 's2'), ('s3','s32'), ('s2','s1')]
>>> len(set(map(frozenset, l)))
2