我有一个这样的清单:
My_dict={0: ['Name1', 'value1', 'value2', 'value3'],
1: ['Name2', 'value4', 'value5', 'value6'],
2: ['Name1', 'value7', 'value8', 'value9']}
我需要从中创建另一个字典 - 将list中的第一个值作为键,对于那些重复的键 - 将值附加到值列表中。 结果我想看到的是:
New_dict= {'Name1': ['value1','value2','value3','value7','value8','value9'],
'Name2': ['value4', 'value5', 'value6']}
现在我正在考虑将字典转换为列表列表并创建新字典(但我在创建新字典时重写了值)
lists=[]
My_dict={0: ['Name1', 'value1', 'value2', 'value3'],
1: ['Name2', 'value4', 'value5', 'value6'],
2: ['Name1', 'value7', 'value8', 'value9']}
for v in My_dict.items():
lists.append(v[1])
new_dict={x[0]: x[1:] for x in lists}
我应该在哪里添加if语句来验证我是否将值附加到new_dict中的现有键,而不是重写
答案 0 :(得分:4)
您可以使用collections.defaultdict
:
>>> from collections import defaultdict
>>> d = defaultdict(list)
>>> for key in sorted(My_dict):
... d[My_dict[key][0]].extend(My_dict[key][1:])
...
>>>
>>> dict(d)
{'Name1': ['value1', 'value2', 'value3', 'value7', 'value8', 'value9'], 'Name2': ['value4', 'value5', 'value6']}
在Python 3.6及更新版本中,如果要处理插入顺序中的值,可以省略sorted()
并迭代My_dict.values()
。
如果列表元素的顺序无关紧要或您需要消除重复项,则可以使用sets:
>>> d = defaultdict(set);
>>> for value in My_dict.values():
... d[value[0]] |= set(value[1:])
...
>>> dict(d)
{'Name1': {'value8', 'value3', 'value2', 'value1', 'value7', 'value9'}, 'Name2': {'value4', 'value5', 'value6'}}