python函数装饰器

不带参数的装饰器

decorator(f)(*arges,**kwarges)

@decorator

def f(): 

pass

带参数的装饰器

decorator(name)(f)(*arges,**kwarges)

def f():

pass

代码示例(不加名字的)

import time
def log():
    def wrapper(*arges,**kwarges):
        strat=time.clock()
        res=func(*arges,**kwarges)
        end=time.clock()
        print 'calling',func.__name__,arges,kwarges
        print 'strat at:',strat,'end at:',end
        return res
    return wrapper
@log
def fun(x,y):
    return x+y
print fun(10,20)


输出结果:

calling: fun (10, 20) {}
strat at: 0.01 end at: 0.01
30

代码示例(加名字的)

import time
def logex(name):
    def log(func):
        def wrapper(*arges,**kwarges):
            start=time.clock()
            res=func(*arges,**kwarges)
            end=time.clock()
            print name,'calling:',fun.__name__,arges,kwarges
            print 'strat at:',strat,'end at:',end
            return res
        return wrapper
     return log
@logex('jack')
def fun(x,y):
    return x+y
print fun(10,20)

输出结果
jack calling: fun (10, 20) {}
start at: 0.0 end at: 0.0
30

 

 

转载于:https://my.oschina.net/u/3754854/blog/1613432

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值