Metaclass中的额外参数

时间:2014-10-26 09:01:42

标签: python metaprogramming metaclass

我写了以下元类:

class FieldHandlerBase(type):
    def __new__(cls, name, bases, dct, model):
        ...
        return super(FieldHandlerBase, cls).__new__(cls, name, bases, dct)

现在,我尝试使用上面的元类动态创建一个类:

FieldHandlerBase(
    '%sFieldHandler' % name,
    (FieldHandler,),
    {rel_type: dct.setdefault(rel_type, ()) for rel_type in REL_TYPES},
    model=name)

但是它让我想到了这个错误:

>           model=name)
E       TypeError: Error when calling the metaclass bases
E           type.__init__() takes no keyword arguments

我不明白为什么,因为我使用正确数量的参数调用元数据库(type来自FieldHandlerBase)。我怎样才能解决这个问题?我需要向FieldHandlerBase传递一个额外的参数,我不想将它包含在dct参数中,因为我只需要在元类级别。

1 个答案:

答案 0 :(得分:1)

您需要编写__init__方法以及__new__方法。否则,python将为您的新类调用type.__init__,它不会接受任何其他参数。

例如

class FieldHandlerBase(type):

    def __init__(cls, name, bases, attrs, model):
        type.__init__(cls, name, bases, attrs)
        cls.model = model

    def __new__(metacls, name, bases, attrs, model):
        ...
        return type.__new__(metacls, name, bases, attrs)

class ExampleFieldHandler(FieldHandler, metaclass=FieldHandlerBase, 
        model="Example"):
    clsvar = "var"

# or 
ExampleFieldHandler = FieldHandlerBase(
    "ExampleFieldHandler",
    (FieldHandler,),
    {"clsvar": "var"},
    model="Example"
)

assert ExampleFieldHandler.model == "Example"