python装饰器在类中的实现


class Test():
    xx = False

    def __init__(self):
        pass

    def test(func):
        def wrapper(self, *args, **kwargs):
            print(self.xx)
            return func(self, *args, **kwargs)
            
        return wrapper

    @test
    def test_a(self,a,b):
        print(f'ok,{a} {b}')

if __name__=='__main__':
    t=Test()
    t.test_a('a','ab')

 新写的例子,封装了一个调用API,需要保存用户调用的一些信息

def log(func):
    @functools.wraps(func)
    def wrapper(self, *args, **kwargs):
        start = time.time()
        result, success, err = None, None, None
        try:
            result = func(self, *args, **kwargs)
            success = True
        except Exception as e:
            err = e
        end = time.time()
        log_dict = {'tableName': args[0],
                    'operation': func.__name__,
                    'startTime': time.strftime(time_format, time.localtime(start)),
                    'endTime': time.strftime(time_format, time.localtime(end)),
                    'elapsedTime': int(end - start),
                    'success': success,
                    'errMsg': err,
                    'account': self.account}
        print(json.dumps(log_dict))
        return result

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM