首頁 >後端開發 >Python教學 >如何結合 Python 中 OrderedDict 和 defaultdict 的功能來建立有序的預設字典?

如何結合 Python 中 OrderedDict 和 defaultdict 的功能來建立有序的預設字典?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-10-28 19:02:02804瀏覽

How can you combine the features of OrderedDict and defaultdict in Python to create an ordered default dict?

實作有序預設字典

OrderedDict 和 defaultdict 是 Python 集合模組中的兩個有用的資料結構。 OrderedDict 保留其元素的插入順序,而 defaultdict 則為缺少的按鍵提供預設值。組合這些功能來建立一個有序的預設字典。

為了實現這一點,我們可以利用Stack Overflow 中配方的修改版本:

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

class DefaultOrderedDict(OrderedDict):
    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

    def __getitem__(self, key):
        try:
            return OrderedDict.__getitem__(self, key)
        except KeyError:
            return self.__missing__(key)

    def __missing__(self, key):
        if self.default_factory is None:
            raise KeyError(key)
        self[key] = value = self.default_factory()
        return value

    def __reduce__(self):
        if self.default_factory is None:
            args = tuple()
        else:
            args = self.default_factory,
        return type(self), args, None, None, self.items()

    def copy(self):
        return self.__copy__()

    def __copy__(self):
        return type(self)(self.default_factory, self)

    def __deepcopy__(self, memo):
        import copy
        return type(self)(self.default_factory,
                          copy.deepcopy(self.items()))

    def __repr__(self):
        return 'OrderedDefaultDict(%s, %s)' % (self.default_factory,
                                               OrderedDict.__repr__(self))</code>

此實作支援OrderedDict 的所有功能和defaultdict,讓您可以使用缺失鍵的預設值建立有序字典。

以上是如何結合 Python 中 OrderedDict 和 defaultdict 的功能來建立有序的預設字典?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn