划分2个不同字典结构的字典



我想划分2个不同结构的字典,我已经找到了我想要的结果,但是我觉得我的代码对于这个问题太长了。有没有更明智的选择?

我有一个只有d2的字典

d2 = {3: {'good best third': 1, 'mind third': 0, 'bad third': 0}, 2: {'good so second': 0, 'mind second': 1, 'bad second': 2}, 1: {'good': 2, 'mind': 0, 'bad': 1}}

,然后要除以父键响应的所有值的总和。为了简单的解释,我把它写在下面:

d1 = {3: 1, 2: 3, 1: 3}

目标是计算d3,其中

dict3 = d2 / d1

我的代码
import copy
temp = []
all_vote_len_dict = {3: {'good best third': 1, 'mind third': 0, 'bad third': 0}, 2: {'good so second': 0, 'mind second': 1, 'bad second': 2}, 1: {'good': 2, 'mind': 0, 'bad': 1}}
d1 = copy.deepcopy(all_vote_len_dict)
d2 = copy.deepcopy(all_vote_len_dict)
# to know total number of vote received per unique post
for key, values in d1.items():
temp.append(sum(values.values()))
temp.append(sum(values.values()))
temp.append(sum(values.values()))
counter=0
for keys, values in d1.items():
for key, value in values.items():
values[key]=temp[counter]
counter +=1
dict3={}
for (k,dict1), (k2,dict2) in zip(d1.items(), d2.items()):
dict3[k]=({k: (dict2[k] / dict1[k]) for k in dict1})
dict3

结果

{3: {'good best third': 1.0, 'mind third': 0.0, 'bad third': 0.0},
2: {'good so second': 0.0,
'mind second': 0.3333333333333333,
'bad second': 0.6666666666666666},
1: {'good': 0.6666666666666666, 'mind': 0.0, 'bad': 0.3333333333333333}}

有更聪明的选择吗?

下面的代码执行"技巧">

d2 = {3: {'good best third': 1, 'mind third': 0, 'bad third': 0},
2: {'good so second': 0, 'mind second': 1, 'bad second': 2}, 1: {'good': 2, 'mind': 0, 'bad': 1}}
d1 = {k: sum(vv for vv in v.values()) for k, v in d2.items()}
# d1 is {3: 1, 2: 3, 1: 3}
d3 = {k: {kk: vv / d1[k] for kk, vv in v.items()} for k, v in d2.items()}
for k, v in d3.items():
print(f'{k} -> {v}')

输出
3 -> {'good best third': 1.0, 'mind third': 0.0, 'bad third': 0.0}
2 -> {'good so second': 0.0, 'mind second': 0.3333333333333333, 'bad second': 0.6666666666666666}
1 -> {'good': 0.6666666666666666, 'mind': 0.0, 'bad': 0.3333333333333333}

最新更新