需求: 统计index函数的执行时间,但是再不改变原函数体代码与调用功能的情况下完成!!! 下面是函数体代码:
import time # 时间功能模块
def index():
time.sleep(3)
print(‘from index’)
index()
代码如何实现?
普通思路如下:
import time # 时间功能模块
def index():
time.sleep(3)
print('from index')
start_time = time.time()
index() # 1.直接在调用index函数的前后添加代码
end_time = time.time()
print('函数index的执行时间为>>>:', end_time-start_time)
完成,没有改变函数体代码及函数的调用方式,符合要求。但是这种代码有个问题,当想在多个地方调用index函数体
代码并且统计函数体的运行时间时,就必须复制粘贴这4行代码:
start_time = time.time()
index()
end_time = time.time()
print(‘函数index的执行时间为>>>:’, end_time-start_time)
这种操作就比较烦,index调用的地方较多 代码不可能反复拷贝。
- 有没有一种办法可以简化这种反复调用某个功能呢?这个时候装饰器就体现作用了。
装饰器模板
# 务必掌握
def outer(func):
def inner(*args, **kwargs):
# 执行被装饰对象之前可以做的额外操作
res = func(*args, **kwargs)
# 执行被装饰对象之后可以做的额外操作
return res
return inner
装饰器语法糖
def outer(func_name):
def inner(*args, **kwargs):
print('执行被装饰对象之前可以做的额外操作')
res = func_name(*args, **kwargs)
print('执行被装饰对象之后可以做的额外操作')
return res
return inner
"""
语法糖会自动将下面紧挨着的函数名当做第一个参数自动传给@函数调用
"""
@outer # func = outer(func)
def func():
print('from func')
return 'func'
@outer # index = outer(index)
def index():
print('from index')
return 'index'
func()
index()
回到刚开始的问题,用装饰器简化后的代码如下:
import time
def outer(func_name):
def inner(*args, **kwargs):
start_time = time.time()
res = func_name(*args, **kwargs)
end_time = time.time()
print('函数的执行时间为>>>:', end_time - start_time)
return res
return inner
"""
语法糖会自动将下面紧挨着的函数名当做第一个参数自动传给@函数调用
"""
@outer # func = outer(func)
def func():
print('from func')
time.sleep(1)
return 'func'
@outer # index = outer(index)
def index():
print('from index')
return 'index'
func()
index()