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
复制代码

 

posted @   Mars.wang  阅读(1285)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
点击右上角即可分享
微信分享提示