如何比较字典并根据它们的键和值计算比率



我有一个字典

dict1={'A': ['15', '3'],'B': ['14', '3']}

和我的每个键的第一个值是我的total所以A的总数是15 B的总数是14。我有另一个字典

dict2={'A': {'A.X': '20.41%',
'A.Y': '30.59%',
'B.X': '20.09%',
'B.Y': '10.00%',
'C.X': '8.04%',
'C.Y': '10.87%'},
'B': {'B.X': '35.15%',
'B.Y': '50.85%',
'C.X': '0.00%',
'C.Y': '0.00%',
'D.X': '14.00%',
'D.Y': '0.00%'}}

我想将每个dict1-key的total应用于相同键的dic2值,以获得total的比率,例如

dict3={'A': {'A.X': '3.06',
'A.Y': '4.59',
'B.X': '3.01',
'B.Y': '1.5',
'C.X': '1.2',
'C.Y': '1.63'},
'B': {'B.X': '4.92',
'B.Y': '7.12',
'C.X': '0',
'C.Y': '0',
'D.X': '1.96',
'D.Y': '0'}}
我想我可以从 开始
new_dict = { key : dict1[key]*dict2[key][0] for key in dict1 if key in dict2 }

但这不起作用。任何帮助都是感激的注:我是python的新手,提前感谢。

你可以通过两层迭代得到你想要的结果:

>>> dict3 = {}
>>> for k1, v1 in dict2.items():
...     total = int(dict1[k1][0]) / 100
...     dict3[k1] = {k2: f'{float(v2[:-1]) * total:.3g}' for k2, v2 in v1.items()}
...
>>> dict3
{'A': {'A.X': '3.06', 'A.Y': '4.59', 'B.X': '3.01', 'B.Y': '1.5', 'C.X': '1.21', 'C.Y': '1.63'}, 'B': {'B.X': '4.92', 'B.Y': '7.12', 'C.X': '0', 'C.Y': '0', 'D.X': '1.96', 'D.Y': '0'}}

相关内容

  • 没有找到相关文章

最新更新