69

dict をサブクラス化しないと、クラスをメソッドに渡すことができるように、クラスをマッピングと見なす必要があります**

from abc import ABCMeta

class uobj:
    __metaclass__ = ABCMeta

uobj.register(dict)

def f(**k): return k

o = uobj()
f(**o)

# outputs: f() argument after ** must be a mapping, not uobj

少なくとも、マッピングの機能が欠落しているというエラーがスローされるまでは、実装を開始できます。

コンテナー タイプのエミュレートを確認しましたが、マジック メソッドを定義するだけでは効果がなく、それABCMetaをオーバーライドして dict として登録すると、アサーションがサブクラスとして検証されますが、失敗しますisinstance(o, dict)。理想的には、使用したくありませんABCMeta

4

3 に答える 3

94

およびメソッドで十分です__getitem__()keys()

>>> class D:
        def keys(self):
            return ['a', 'b']
        def __getitem__(self, key):
            return key.upper()


>>> def f(**kwds):
        print kwds


>>> f(**D())
{'a': 'A', 'b': 'B'}
于 2011-12-22T08:52:13.950 に答える
32

関数に渡すための要件を満たすだけでなく、マッピングを作成しようとしている場合は、本当にから継承する必要がありますcollections.abc.Mappingドキュメントで説明されているように、実装する必要があるのは次のとおりです。

__getitem__
__len__
__iter__

__contains__Mixin は、keysitemsvaluesget__eq__、およびのすべてを実装します __ne__

于 2011-12-23T08:37:12.457 に答える