[英]Summing specific elements in nested dict
我有3个使用嵌套字典表示的袋子。 它们的键是“ bag1”,“ bag2”和“ bag3”,并且依次包含不同数量的不同颜色的球,每种颜色类别也由字典表示。 如何以仅在每个包中添加所有相应颜色的字典结尾? 例如dict1 = {'bag1': { 'red' : 2, 'blue' : 5, 'green' : 7}, 'bag2' : { 'red' : 3, 'blue': 4, 'green': 8}}
。 现在,我想以另一种形式的最终字典结束: dict2 = { 'red' : 5, 'blue': 9, 'green': 15}
。 有人可以为我提供执行此操作的功能吗?
首先,您要创建结果字典:
dict2 = {}
for key in dict1['bag1'].keys():
dict2[key] = 0
然后填写
for bag in dict1.values():
for key, value in bag.items():
dict2[key] += value
在递归函数get_value
下面,它将从JSON查找键的值。
import json
def get_value(key, mydict):
if key in mydict:
return mydict[key]
if type(mydict) is dict:
for i in mydict:
if type(i) is dict:
return get_value(key, i)
return 0
def get_sum(dict1, dict2):
red, blue, green = 0, 0, 0
red = get_value('red', dict1) + get_value('red', dict2)
blue = get_value('blue', dict1) + get_value('blue', dict2)
green = get_value('green', dict1) + get_value('green', dict2)
return {
'red':red,
'blue': blue,
'green':green
}
if __name__=="__main__":
dict1 = {'bag1': { 'red' : 2, 'blue' : 5, 'green' : 7}, 'bag2' : { 'red' : 3, 'blue': 4, 'green': 8}}
dict2 = { 'red' : 5, 'blue': 9, 'green': 15}
final_sum = get_sum(dict1, dict2)
print(final_sum)
输出: {'red': 5, 'blue': 9, 'green': 15}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.