python 装饰器

import time

def wrap(func):
    print("\n")
    print("装饰器内部处理逻辑.... ")
    def inner(*args, **kwargs):
        fun_name = func.__name__
        num = len(args)
        params = ""
        print(f"fun_name is {fun_name}")
        print(f"params len is {num}")
        print(f"args is {args}")
        print(f"kwargs.keys() is {kwargs.keys()}")
        if num > 0:
            params = '"{0}"'.format(args[0])
        if num > 1:
            for i in range(1, len(args)):
                params = '{0}, "{1}"'.format(params, args[i])
        for k in kwargs.keys():
            if isinstance(kwargs[k], str):
                params = '{0}, {1}="{2}"'.format(params, k, kwargs[k])
            else:
                params = "{0}, {1}={2}".format(params, k, kwargs[k])
        params = "({0})".format(params)
        print(f"params is {params}")
        print("装饰器内部处理逻辑结束 \n")
        return "{0} {1}".format(fun_name, params), 0, func(*args,**kwargs)
    return inner

@wrap
def cost(param1, param2, param3, param4):
    print("执行函数内部逻辑")
    return "cost_fuction"

if __name__ == "__main__":
    result = cost("123", "456", "789", {"name":"koukou"})
    print(result)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值