我正在干一些帶有類代碼副本并粘貼的代碼。我已將代碼分為不同的子類,以實(shí)現(xiàn)所需的不同元素,但是代碼的殘余之一是,每個(gè)類的特定裝飾器都被稱為通用方法。在此示例中,它就是foo方法。@some_decorator_function過去是從每個(gè)類的另一個(gè)命名空間導(dǎo)入的。現(xiàn)在,裝飾器僅從父類中調(diào)用一次,因此它不知道用作子類的裝飾器需要選擇它。有沒有辦法將要裝飾的函數(shù)委托給子類?我的想法(并NotImplementedError立即提出,因?yàn)閷求值):class X: def some_decorator_function(): raise NotImplementedError @some_decorator_function() def foo(self): return "Yo!"def concrete_function(func): passclass Y(X): def some_decorator_function(): concrete_functionY().foo
2 回答

RISEBY
TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超5個(gè)贊
您可以將裝飾器轉(zhuǎn)換為更通用的模式。
def class_defined_decorator(func):
def wrapper(*args, **kwargs):
return args[0]._decorator(func, *args, **kwargs)
return wrapper
class Base(object):
def _decorator(self, func, *args, **kwargs):
raise NotImplementedError
@class_defined_decorator
def foo(self):
pass
class Child(Base):
def _decorator(self, func, *args, **kwargs):
# Do decorator behavior
return func(*args, **kwargs)
如果必須支持使用相同的裝飾器裝飾靜態(tài),類和實(shí)例方法,則可以通過使裝飾器返回描述符來提高想象力。
添加回答
舉報(bào)
0/150
提交
取消