使用缺少的键值对更新嵌套字典
Update nested dict with missing key value pairs
我有一个具有唯一 ID 的字典和对应于基本位置的键值对的嵌套字典:
{'925328413719459770': {'N': 14,
'NNW': 116,
'NW': 38,
'S': 1,
'SE': 2,
'SSE': 1,
'W': 16,
'WNW': 146,
'WSW': 16}}
但是,并非所有嵌套的字典都包含 16 个可能的基本位置中的每一个:
cp = ["N", "NNE", "NE", "ENE", "E", "ESE", "SE", "SSE",
"S", "SSW", "SW", "WSW", "W", "WNW", "NW", "NNW"]
我能够找出字典中的基数位置集与完整列表之间的差异 cp
for leg in legdict.values():
print(list(set(cp) - set(leg.keys())))
['ESE', 'SSW', 'NNE', 'NE', 'ENE', 'SW', 'E']
然后如何用缺失的位置更新嵌套字典并将它们的值设置为 0?输出将是这样的:
{'925328413719459770': {'N': 14,
'NNW': 116,
'NW': 38,
'S': 1,
'SE': 2,
'SSE': 1,
'W': 16,
'WNW': 146,
'WSW': 16,
'ESE': 0,
'SSW': 0,
'NNE': 0,
'NE': 0,
'ENE':0,
'SW': 0,
'E': 0 }}
在 python 中是否有使用 update()
方法执行此操作的有效方法,或者可以使用列表更新字典同时将该列表的所有元素设置为 0?实际 legdict
非常大,因此任何有关有效方法的建议都将不胜感激。
这个怎么样:
cardinal_positions = [
"N", "NNE", "NE", "ENE", "E", "ESE", "SE", "SSE",
"S", "SSW", "SW", "WSW", "W", "WNW", "NW", "NNW"
]
def fill_missing_keys(the_huge_dict):
"""Fills in missing cardinal positions with 0"""
for inner_dict in the_huge_dict.values():
for key in cardinal_positions:
if key not in inner_dict:
inner_dict[key] = 0
应该相当高效,因为它不制作任何副本,它只是遍历所有内容并在必要时填充缺失的键。
作为一般规则,您应该始终首先采用最简单的解决方案。如果发现太慢,以后再优化。
我有一个具有唯一 ID 的字典和对应于基本位置的键值对的嵌套字典:
{'925328413719459770': {'N': 14,
'NNW': 116,
'NW': 38,
'S': 1,
'SE': 2,
'SSE': 1,
'W': 16,
'WNW': 146,
'WSW': 16}}
但是,并非所有嵌套的字典都包含 16 个可能的基本位置中的每一个:
cp = ["N", "NNE", "NE", "ENE", "E", "ESE", "SE", "SSE",
"S", "SSW", "SW", "WSW", "W", "WNW", "NW", "NNW"]
我能够找出字典中的基数位置集与完整列表之间的差异 cp
for leg in legdict.values():
print(list(set(cp) - set(leg.keys())))
['ESE', 'SSW', 'NNE', 'NE', 'ENE', 'SW', 'E']
然后如何用缺失的位置更新嵌套字典并将它们的值设置为 0?输出将是这样的:
{'925328413719459770': {'N': 14,
'NNW': 116,
'NW': 38,
'S': 1,
'SE': 2,
'SSE': 1,
'W': 16,
'WNW': 146,
'WSW': 16,
'ESE': 0,
'SSW': 0,
'NNE': 0,
'NE': 0,
'ENE':0,
'SW': 0,
'E': 0 }}
在 python 中是否有使用 update()
方法执行此操作的有效方法,或者可以使用列表更新字典同时将该列表的所有元素设置为 0?实际 legdict
非常大,因此任何有关有效方法的建议都将不胜感激。
这个怎么样:
cardinal_positions = [
"N", "NNE", "NE", "ENE", "E", "ESE", "SE", "SSE",
"S", "SSW", "SW", "WSW", "W", "WNW", "NW", "NNW"
]
def fill_missing_keys(the_huge_dict):
"""Fills in missing cardinal positions with 0"""
for inner_dict in the_huge_dict.values():
for key in cardinal_positions:
if key not in inner_dict:
inner_dict[key] = 0
应该相当高效,因为它不制作任何副本,它只是遍历所有内容并在必要时填充缺失的键。
作为一般规则,您应该始终首先采用最简单的解决方案。如果发现太慢,以后再优化。