1、什么是python函数装饰器(下文简称装饰器)?
装饰器实际上就是一个函数。这个函数有两个特别之处:参数是一个函数,返回值也是一个函数。
2、从一个简单案例了解装饰器的使用:在所有函数执行的时候,都要打印:XX函数执行了。如add(),打印add函数执行了。
from functools import wraps
def my_log(func):
# 需要使用functools.wraps在装饰器中的函数上把传进来的这个函数进行一个包裹,这样就不会丢失原来函数的__name__等属性。
@wraps(func)
# 装饰器定义的函数,要使用*args,**kwargs两对兄弟的组合
def wrapper(*args, **kwargs):
print(func.__name__ + "执行了...")
# 并且在这个函数中定义原始函数的时候也要把*args,**kwargs传进去
func(*args, **kwargs)
return wrapper
# 装饰器使用是通过@符号,放在函数的上面
@my_log
def add(a, b):
print(a + b)
@my_log
def hello():
print("hello world!")
hello()
print(hello.__name__)
add(3,6)
print(add.__name__)
3、用途:常用于日志记录中。