1 回答

TA貢獻(xiàn)2019條經(jīng)驗(yàn) 獲得超9個(gè)贊
您可以在類外部定義裝飾器,它會(huì)正常工作,但您需要self在包裝器簽名中顯式引用。
這樣做的原因是因?yàn)楹瘮?shù)內(nèi)的所有定義僅在調(diào)用該函數(shù)時(shí)才會(huì)計(jì)算。當(dāng)函數(shù)test被調(diào)用時(shí),它已經(jīng)綁定到實(shí)例并且self將存在于其命名空間中。
import functools, logging
logging.basicConfig(format='%(asctime)s - %(levelname)s - %(funcName)s:%(message)s',
datefmt='%Y-%m-%d %I:%M:%S %p',
level=logging.DEBUG)
def log(func):
@functools.wraps(func)
def wrapper_log(self, *args, **kwargs):
logging.info(f"Started (instance {self.bar})")
func(self, *args, **kwargs)
logging.info(f"Finished (instance {self.bar}")
return func(self, *args, **kwargs)
return wrapper_log
class Foo:
def __init__(self, bar):
self.bar = bar
@log
def test(self, a, b, c):
pass
foo = Foo("bar")
foo.test(1, "b", [3, 4])
這將輸出
2020-10-05 11:31:20 PM - INFO - wrapper_log:Started (instance bar)
2020-10-05 11:31:20 PM - INFO - wrapper_log:Finished (instance bar
添加回答
舉報(bào)