当前位置 : 主页 > 编程语言 > python >

python – 是否有内置的dict.get()的递归版本?

来源:互联网 收集:自由互联 发布时间:2021-06-25
我有一个嵌套的字典对象,我希望能够检索具有任意深度的键的值.我可以通过继承dict来做到这一点: class MyDict(dict):... def recursive_get(self, *args, **kwargs):... default = kwargs.get('default')... curs
我有一个嵌套的字典对象,我希望能够检索具有任意深度的键的值.我可以通过继承dict来做到这一点:

>>> class MyDict(dict):
...     def recursive_get(self, *args, **kwargs):
...         default = kwargs.get('default')
...         cursor = self
...         for a in args:
...             if cursor is default: break
...             cursor = cursor.get(a, default)
...         return cursor
... 
>>> d = MyDict(foo={'bar': 'baz'})
>>> d
{'foo': {'bar': 'baz'}}
>>> d.get('foo')
{'bar': 'baz'}
>>> d.recursive_get('foo')
{'bar': 'baz'}
>>> d.recursive_get('foo', 'bar')
'baz'
>>> d.recursive_get('bogus key', default='nonexistent key')
'nonexistent key'

但是,我不希望子类dict来获取此行为.是否有一些具有等效或类似行为的内置方法?如果没有,是否有任何标准或外部模块提供此行为?

我目前正在使用Python 2.7,但我也很想知道3.x解决方案.

一个非常常见的模式是使用空dict作为默认值:

d.get('foo', {}).get('bar')

如果你有多个键,你可以使用reduce(请注意,必须导入Python 3中的reduce:来自functools import reduce)才能多次应用该操作

reduce(lambda c, k: c.get(k, {}), ['foo', 'bar'], d)

当然,您应该考虑将其包装到函数(或方法)中:

def recursive_get(d, *keys):
    return reduce(lambda c, k: c.get(k, {}), keys, d)
网友评论