被修饰函数上加上参数的装饰器

本文介绍了一种使用Python装饰器来记录函数运行时间的方法。通过装饰器可以方便地为多个函数添加计时功能,无需在每个函数内部重复相同的计时代码。文中给出了具体的装饰器实现代码,并展示了两个应用实例。
import time
#装饰器的架子如下
def timmer(func):
def wrapper(*args,**kwargs):
start_time = time.time()
res = func(*args,**kwargs) #这一步就是在运行test
stop_time = time.time()
print('程序运行时间是%s' %(start_time - stop_time))
return res
return wrapper

@timmer #相当test = timmer(test)
def test(name,age): #被修饰函数
time.sleep(0.5)
print('test函数运行完毕,名字是%s,年龄是%s' %(name,age))
return '这是test 的返回值'

@timmer
def test1(name,age,grender): #被修饰函数
time.sleep(0.9)
print('test函数运行完毕,名字是%s,年龄是%s,性别%s' %(name,age,grender))
return '这是test 的返回值'

res = test('liuhaiquan',18) #就是在运行wrapper
print(res)
test1('doudou',12,'dog')

转载于:https://www.cnblogs.com/lhqlhq/p/8744678.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值