当前位置: 首页 > 面试题库 >

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

吴涵育
2023-03-14
问题内容

我有一个嵌套的字典对象,并且希望能够检索具有任意深度的键的值。我可以通过子类化做到这一点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必须导入:)from 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)


 类似资料:
  • 问题内容: 在开发Python代码时,通常会在解释器中以即席方式对其进行测试。我将对其进行测试,找到一个错误,修复该错误并保存,然后使用内置函数进行再次测试。 但是,假设我有,并且在测试时发现了一个错误并进行了修复。现在调用不会递归地重新导入。我必须手动重新导入依赖项(通过执行类似,或的操作,或者,如果我更改了一大堆依赖项并丢失了需要重新加载的内容的信息,则需要重新启动整个解释器。 更为方便的是,

  • 问题内容: 我一直在浏览教程和书籍,但是找不到内置产品函数,即与sum()相同类型的产品,但是找不到诸如的任何内容。 是通过导入运算符在列表中找到商品的唯一方法吗? 问题答案: 发音 是的,这是对的。Guido拒绝了内置prod()函数的想法,因为他认为很少需要它。 Python 3.8更新 在Python 3.8中, prod() 已添加到math模块: 用reduce()替代 正如您建议的那样

  • 问题内容: 我有以下代码失败,并出现以下错误: 超过最大递归深度 我试图重写此代码以允许尾递归优化(TCO)。我相信,如果发生了TCO,则该代码应该会成功。 我是否应该得出结论,Python不执行任何类型的TCO,还是只需要以不同的方式定义它? 问题答案: 你可以通过这样的转换来手动消除递归

  • 我有以下代码失败,错误如下: RuntimeError:超出最大递归深度 我试图重写它以允许尾部递归优化(TCO)。我相信,如果发生了TCO,那么这段代码应该是成功的。 我应该得出结论,Python不做任何类型的TCO,还是我只需要以不同的方式定义它?

  • 我时不时地使用switch语句。我经常发现自己想在函数中使用return语句。我想知道以这种方式编写的switch语句是否仍然是尾部调用优化的。 需要更改什么才能使

  • 目前,我的问题有四个指标。每一种方法都是完全不同的(每一种方法都有不同的单位,不同的范围等等),而且每一种方法都是外部加权的。我用口水来得分。 我只有一个分数级别(),我必须找到一种方法,将这些度量的各个分数适当地组合到一个值上 目前最重要的问题是度量值的范围可能有很大的不同。 因此,例如,如果在一次移动之后,一个可能范围较小的度量的得分提高了,比如说10%,那么这可能完全被一次替代移动所抵消,该