假设我有一个从 pickle 文件中提取的嵌套字典,其中包含各种级别,我想通过只给出最后一个键来获取值。考虑到自己的“分支”,键是唯一的。
主要问题是我有多个键和级别:
dict = {
'A': {
'X': {
1: [...],
2: [...]
},
'Y': {
3: [...],
4: [...]
}
}
'B': {
'G': {
'H': {
'Z': [...]
}
}
}
'C': [...]
}
我该怎么做?
答案 0 :(得分:2)
一个简单的解决方案是一个递归函数,它甚至适用于嵌套的、嵌套的字典
outer_dict = {'outer': {'inner': 10, 'even_inner': {'innerst': 25}}}
和函数:
def get_val(search_dict, key):
""" recursive searching the dict """
for elem in search_dict:
if elem == key:
return search_dict[elem]
if isinstance(search_dict[elem], dict):
retval = get_val(search_dict[elem], key)
if retval is not None:
return retval
value = get_val(outer_dict, 'innerst')
print(value)
>> 25
问题: 如果密钥不是唯一的,您将只获得第一场比赛。如果键可以多次出现,您将需要一个列表来填充值。
下次请举例!