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/

10-10 10:58