装饰器是通过闭包的方式实现的
- 外部函数接收一个函数作为函数的参数变量,内部函数中执行这个函数;
- 内部函数接收需要的参数给执行的函数,返回执行结果;
- 内部函数中可以添加额外的功能代码;
- 外函数将内函数返回
装饰器范例:
- 装饰器遵循开放封闭原则,及原函数是封闭的,但是可以通过装饰器来修改原函数。
- 装饰器其本质就是闭包,是特殊的闭包函数。
def decorater(func):
print('------------>>>>1')
def inner():
func()
print('出去旅游')
print('开始赏景')
print('开始购物')
print('旅游结束')
print('--------------->>2')
return inner()
@decorater # 在不改变原来函数的基础上,给函数增加新的功能
def happy():
print('我到某个地方只办三件事')
带参数的装饰器:
def decorater(func):
print('------------>>>>1')
# house带参数 inner也必须带参数,func也要带参数
def inner(area):
func(area)
print('开始水电安装')
print('开始刷漆')
print('开始铺地板')
print('装修完成')
print('------>>2')
return inner
@decorater
def house(area):
print('这是一个毛坯房面积是%d平方米' % area)
house(20)
装饰器的使用场景:
- 引入日志
- 函数执行时间统计
- 执行函数前预备处理
- 执行函数前的清理功能
- 权限效验等
编写一个计时的装饰器
# 编写一个查看时间戳的函数
import time
def func1():
time.sleep(2)
print("func1.....")
# 查看程序运行时间戳
start = time.time()
print("Start running time: %s" % start)
func1()
end = time.time()
print("End running time: %s" % end)
print('Running time: %s Seconds' % (end - start))
编写装饰器——统计运行时间的装饰器
import time
def runtime(func):
def inner():
start = time.time()
a = func()
end = time.time()
print(f"函数执行用时{end - start}s")
return print(a) # 返回传递的func()的返回值
return inner
# @语法糖:其实就是将被装饰的函数名传递给装饰器runtime去执行runtime 返回内函数inner,赋值给同名的被装饰函数变量,函数被装饰之后,已经不是原来的函数了
@runtime # func1 = runtime(func1)
def func1():
time.sleep(2)
print("func1......")
return 10000
# return 10000 如何实现返回func1的返回值?在inner函数里添加
func1()