从嵌套字典中检索单级的Python方法

时间:2020-07-12 17:43:25

标签: python dictionary

我正在尝试从嵌套字典中检索单个级别。因此,例如,给定下面的字典,我希望在第一级和第二级看到以下结果。

nested_dict = {
  'foo':'bar',
  'baz':{
    'foo':'baz'
  }}

# level 0
{'foo':'bar'}

# level 1
{'foo':'baz'}

我可以使用dict理解来检索第一级:

{k:v for (k,v) in nested_dict.items() if type(v) is not dict}
>>> {'foo':'bar'}

或使用递归检索指定级别:

def get_level(nested_dict, level):
  if level == 0:
    return {k:v for (k,v) in nested_dict.items() if type(v) is not dict}
  else:
    this_level = {}
    for (k,v) in nested_dict.items():
      if type(v) is dict:
        this_level.update(v)
    return get_level(this_level, level - 1)

get_level(nested_dict, 1)
>>> {'foo':'baz'}

我现在想知道是否有更多的Pythonic / clean /开箱即用的方式来检索嵌套词典的级别(如我上面已经做过的),如果需要的话可以借助软件包。

1 个答案:

答案 0 :(得分:1)

如评论中所述,我假设您没有重复的内容

nested_dict = {
  'foo':'bar',
  'baz':{
    'foo':'baz',
    'fee': {
        'foo': 'fee'
    }
  },
  'baz2':{
    'foo2':'baz2'
  }
  }

def get_level(dct, level):
    if level == 0:
        yield from ((k, v) for k, v in dct.items() if not isinstance(v, dict))
    else:
        yield from ((kk, vv) for v in dct.values() if isinstance(v, dict) for kk, vv in get_level(v, level-1))


print(dict(get_level(nested_dict, 1)))

打印:

{'foo': 'baz', 'foo2': 'baz2'}

print(dict(get_level(nested_dict, 2)))

打印:

{'foo': 'fee'}