some_dict = {"firstname": "Albert", "nickname": "Albert", "surname": "Likins", "username": "Angel"}
我想返回我的字典的键,其中它们的值存在多次。
有人可以告诉我如何实现吗?
a_list = []
for k,v in some_dict.iteritems():
if v in some_dict.values() and v != some_dict.keys(k):
a_list.append(k)
最佳答案
首先,将字典翻转成反向乘法,将每个值映射到它映射到的所有键。像这样:
>>> some_dict = {"firstname":"Albert","nickname":"Albert","surname":"Likins","username":"Angel"}
>>> rev_multidict = {}
>>> for key, value in some_dict.items():
... rev_multidict.setdefault(value, set()).add(key)
现在,您只需要在multidict中寻找具有多个值的键。这很容易:
>>> [key for key, values in rev_multidict.items() if len(values) > 1]
['Albert']
除了multidict键以外,其他都是原始dict值。因此,这是每个重复值,而不是所有与每个重复值匹配的键。但是您知道匹配每个重复值的所有键是什么吗?
>>> [values for key, values in rev_multidict.items() if len(values) > 1]
[{'firstname', 'nickname'}]
当然,这为您提供了一套 list 。如果要将其拼合为单个列表或集合,这很容易。您可以使用
chain.from_iterable
,嵌套理解或任何其他常用技巧。例如:>>> set(chain.from_iterable(values for key, values in rev_multidict.items() if len(values) > 1))
{'firstname', 'nickname'}
关于python - 查找具有重复值的字典键,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/20672238/