第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

Python 裝飾器作為類成員

Python 裝飾器作為類成員

動(dòng)漫人物 2023-10-11 15:56:55
我想為類函數(shù)創(chuàng)建一個(gè)裝飾器,它將在函數(shù)的開頭和結(jié)尾處生成日志消息,其中包含特定于運(yùn)行該函數(shù)的類實(shí)例的信息。我嘗試通過將裝飾器創(chuàng)建為類成員來實(shí)現(xiàn)此目的,但這不起作用,因?yàn)檠b飾器期望函數(shù)作為第一個(gè)參數(shù),但作為類方法,它需要是self. 這是我到目前為止所寫的不起作用的內(nèi)容:import functools, logginglogging.basicConfig(format='%(asctime)s - %(levelname)s - %(funcName)s:%(message)s',                             datefmt='%Y-%m-%d %I:%M:%S %p',                            level=logging.DEBUG)class Foo:    def __init__(self, bar):        self.bar = bar            def log(func):        @functools.wraps(func)        def wrapper_log(*args, **kwargs):            logging.info(f"Started (instance {self.bar})")            func(*args, **kwargs)            logging.info(f"Finished (instance {self.bar}")            return func(*args, **kwargs)        return wrapper_log            @log    def test(self, a, b, c):        pass    foo = Foo("bar")foo.test(1, "b", [3, 4])我無法將其移出類并通過裝飾類函數(shù)來將類實(shí)例作為參數(shù)傳遞,@log(self)因?yàn)閟elf它不存在于函數(shù)之外。我怎樣才能做到這一點(diǎn)?
查看完整描述

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


查看完整回答
反對 回復(fù) 2023-10-11
  • 1 回答
  • 0 關(guān)注
  • 100 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號