python如何修改装饰器中参数
本文实例为大家分享了python修改装饰器中参数的具体代码,供大家参考,具体内容如下
案例:
为分析程序内哪些函数执行时间开销较大,我们需定义一个带timeout参数的装饰器
需求:
统计被装饰函数的运行时间
时间大于timeout时,将此次函数调用记录到log日志中
运行时可以修改timeout的值
如何解决这个问题?
- 定义一个装饰器,计算函数执行时间,并与timeout比较,当大于timeout时候,通过logging模块打印出日志信息
- 在包裹函数中添加一个函数,通过这个函数来修改timeout变量
- 在python3中用nonlocal来声明嵌套作用域中的变量引用,在python2中可以通过把timeout参数变成列表,通过列表索引来进行改值
#!/usr/bin/python3
importtime
importlogging
fromrandomimportrandint
defrun_time(timeout):
"""
定义检查函数运行时间,并打印对应函数运行时间超出设定时间日志,并支持更改timeout
"""
#python2
#timeout=[timeout]
#真正包裹函数
defout_wrapper(func):
defwrapper(*args,**kwargs):
start_time=time.time()
result=func(*args,**kwargs)
used_time=time.time()-start_time
#对于超出timeout的函数进行日志打印
ifused_time>timeout:
msg='%s:%s>%s'%(func.__name__,used_time,timeout)
logging.warn(msg)
#python2
#ifused_time>timeout[0]:
#msg='%s:%s>%s'%(func.__name__,used_time,timeout[0])
#logging.warn(msg)
#returnresult
#设置timeout参数值
defset_timeout(value):
nonlocaltimeout
timeout=value
wrapper.set_timeout=set_timeout
#python2
#defset_timeout(value):
#timeout[0]=value
#wrapper.set_timeout=set_timeout
returnwrapper
returnout_wrapper
@run_time(1.5)
deffunc():
#随机有50%的几率程序沉睡1秒
whilerandint(0,1):
time.sleep(1)
print('func_run')
if__name__=="__main__":
for_inrange(10):
func()
print('_'*50)
#更改run_time装饰器中timeout参数
func.set_timeout(2)
for_inrange(10):
func()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。