将 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中文网其他相关文章!