当然,我们也可以同时使用多个装饰器。
代码语言:javascript复制def my_logging(func):
def wrapper():
print('logging - {} is running'.format(func.__name__))
func() # run func() Equivalent run f1()
return wrapper
def bold(func):
def wrapper():
print("<b>")
func()
print("</b>")
return wrapper
def italic(func):
def wrapper():
print("<i>")
func()
print("</i>")
return wrapper
@my_logging
@bold
@italic
def f1():
print("f1")
f1()
其实上面这段 code 也相当这样的
代码语言:javascript复制def my_logging(func):
def wrapper():
print('logging - {} is running'.format(func.__name__))
func() # run func() Equivalent run f1()
return wrapper
def bold(func):
def wrapper():
print("<b>")
func()
print("</b>")
return wrapper
def italic(func):
def wrapper():
print("<i>")
func()
print("</i>")
return wrapper
def f1():
print("f1")
f1 = my_logging(bold(italic(f1)))
f1()
这边只需要稍微注意一下执行的顺序?,刚刚的 f1() 是没有带入参数的,今天假如我希望带入参数呢?
代码语言:javascript复制def my_logging(func):
def wrapper(*args, **kwargs):
print('logging - {} is running'.format(func.__name__))
func(*args, **kwargs)
return wrapper
@my_logging
def f1(*args, **kwargs):
print("f1")
for thing in args:
print('hello {}'.format(thing))
for name, value in kwargs.items():
print('{0} = {1}'.format(name, value))
f1('twtrubiks', apple='fruit', cabbage='vegetable')
使用 *args **kwargs 这样写的话,不管 f1() 带入什麽参数都不用担心?。装饰器还有更大的弹性,像是今天如果我希望将装饰器带入参数。
代码语言:javascript复制def my_logging(level):
def decorator(func):
def wrapper(*args, **kwargs):
if level == "1":
print('level {} logging - {} is running'.format(level, func.__name__))
elif level == "2":
print('level {} logging - {} is running'.format(level, func.__name__))
func(*args, **kwargs)
return wrapper
return decorator
@my_logging(level="1")
def f1(*args, **kwargs):
print("f1")
for thing in args:
print('hello {}'.format(thing))
for name, value in kwargs.items():
print('{0} = {1}'.format(name, value))
f1('twtrubiks', apple='fruit', cabbage='vegetable')
这边简单说明,就是为了要将装饰器带入参数,我们必须再包一层。