当值不是uniqu时,在python字典中转置值和键

2024-04-25 19:17:24 发布

您现在位置:Python中文网/ 问答频道 /正文

我想将键更改为python字典中的值,但原始字典中的值不是唯一的。

以下是我所拥有的:

year_person = {2000: ‘Linda’, 2001: ‘Ron’, 2002: ‘Bruce’, 2003: ‘Linda’, 2004: ‘Bruce’, 2005 ‘Gary’, 2006: ‘Linda’}

我想把它改成:

person_year = {‘Linda’: 2000, ‘Ron’: 2001, ‘Bruce’: 2002, ‘Linda’, 2003: ‘Bruce’, 2004 ‘Gary’, 2005: ‘Linda’: 2006}

当我试图使用for循环转换它时,我只为每个人得到一对匹配的。


Tags: for字典yearpersongarybrucelindaron
3条回答

只是为了提供当前答案中可能缺少的其他选项和信息:

如果你确信你的价值观是独一无二的,因此可以成为关键,最简单的方法就是听写理解:

year_person = {2000: 'Linda', 2001: 'Ron', 2002: 'Bruce', 2003: 'Linda', 2004: 'Bruce', 2005: 'Gary', 2006: 'Linda'}
person_year = {key: value for (value, key) in year_person.items()}

当然,在您的情况下,它们不是,所以这不起作用(因为它只给出最后找到的值):

person_year = {'Bruce': 2004, 'Linda': 2006, 'Ron': 2001, 'Gary': 2005}

相反,我们可以在dict comp中使用嵌套的list comp:

{key: [value for value, check_key in year_person.items() if check_key==key] for key in year_person.values()}

给我们:

{'Bruce': [2002, 2004], 'Linda': [2000, 2003, 2006], 'Ron': [2001], 'Gary': [2005]}

这是可行的,但由于必须循环遍历每个条目的整个字典,因此效率不高。更好的解决方案是由alan给出的the ^{} solution,它只需要一个循环。

也可以使用defaultdict:

year_person = {2000: 'Linda', 2001: 'Ron', 2002: 'Bruce', 2003: 'Linda', 2004: 'Bruce', 2005: 'Gary', 2006: 'Linda'}

from collections import defaultdict
d = defaultdict(list)
for k, v in year_person.items():
    d[v].append(k)

print dict(d)
>>> {'Bruce': [2002, 2004], 'Linda': [2000, 2003, 2006], 'Ron': [2001], 'Gary': [2005]}

你不想达到的目标在技术上是不可行的。字典的键不能重复,因为如果重复,则不能用键为字典唯一索引。

您可以做的是创建(键,值)对的字典,其中value是具有相同键的所有项的列表。为了达到这个目的,你可以做如下的事情

>>> person_year={}
>>> [person_year.setdefault(v,[]).append(k) for (k,v) in year_person.iteritems()]
[None, None, None, None, None, None, None]
>>> person_year
{'Bruce': [2002, 2004], 'Linda': [2000, 2003, 2006], 'Ron': [2001], 'Gary': [2005]}
>>> 

注意,如果您只对键值对感兴趣,而不是对字典本身感兴趣,那么您可以将其存储为一个元组列表,如下所示

>>> [(v,k) for k,v in year_person.iteritems()]
[('Linda', 2000), ('Ron', 2001), ('Bruce', 2002), ('Linda', 2003), ('Bruce', 2004), ('Gary', 2005), ('Linda', 2006)]
>>>

相关问题 更多 >