首页  >  文章  >  后端开发  >  如何在 Python 中创建具有默认值的有序字典?

如何在 Python 中创建具有默认值的有序字典?

Linda Hamilton
Linda Hamilton原创
2024-10-28 03:37:30285浏览

How can I create an ordered dictionary with default values in Python?

将 OrderedDict 和 defaultdict 组合为有序默认字典

OrderedDict 和 defaultdict 是 Python 集合模块中两个强大的数据结构。 OrderedDict 维护其元素的顺序,而 defaultdict 为缺失的键提供默认值。然而,将这些功能组合在一个数据结构中可能具有挑战性。

使用 DefaultOrderedDict 自定义实现

一种可能的解决方案是创建一个名为 DefaultOrderedDict 的自定义类,该类继承自OrderedDict 并添加默认值功能。下面是一个受 Stack Overflow 答案启发的实现:

<code class="python">from collections import OrderedDict, Callable

class DefaultOrderedDict(OrderedDict):
    # Source: http://stackoverflow.com/a/6190500/562769
    def __init__(self, default_factory=None, *a, **kw):
        if (default_factory is not None and
           not isinstance(default_factory, Callable)):
            raise TypeError('first argument must be callable')
        OrderedDict.__init__(self, *a, **kw)
        self.default_factory = default_factory

    # Override __getitem__ to handle missing keys
    def __getitem__(self, key):
        try:
            return OrderedDict.__getitem__(self, key)
        except KeyError:
            return self.__missing__(key)

    # Raise KeyError if no default factory is provided
    def __missing__(self, key):
        if self.default_factory is None:
            raise KeyError(key)
        self[key] = value = self.default_factory()
        return value

    # ... (additional methods and overrides for copy, deepcopy, and repr)</code>

这个 DefaultOrderedDict 类结合了 OrderedDict 和 defaultdict 的功能,允许按顺序访问元素并为缺失的键提供默认值。

以上是如何在 Python 中创建具有默认值的有序字典?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn