python 装饰器

def print_run_time(func):
    def wrapper(*args, **kw):
        local_time = time.time()
        func(*args, **kw)
        print('Function [%s] run time is %.2f s' % (func.__name__, time.time() - local_time))

    return wrapper

 

简单的计算方法耗时

import time


def decorator(func):
    def wrapper(*args, **kwargs):
        start_time = time.time()
        func(*args, **kwargs)
        print(args, kwargs)
        end_time = time.time()
        print(end_time - start_time)

    return wrapper


@decorator
def func(name):
    time.sleep(1)


func(name='方法1')  # 函数调用

打印

 

 

def outer(outer_args):
    '''
    带参装饰器
    :param outer_args:
    :return:
    '''

    def middle(func):
        def wrapper(*args, **kwargs):
            print("before func")
            print("use args: " + outer_args)
            wrapper_result = func(*args, **kwargs)
            print("after func")
            return wrapper_result

        return wrapper

    return middle


@outer("hello")
def foo(a, b):
    return a + b


res = foo(1, 1)
print(res)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值