假设我有个装饰师:
def decorator_with_args(decorator_arg1, decorator_arg2):
def decorator(func):
def wrapped(*args, **kwargs):
if decorator_arg1 == 'arg1' and decorator_arg2 == 'arg2':
return func(*args, **kwargs)
return wrapped
return decorator通常,您可以像这样装饰一个函数:
@decorator_with_args('arg1', 'arg2')
def function():
return 'foo'
>>> foo = function()
'foo'如何不使用@语法来调用它?
我知道,如果它只是一个单层的装饰器(即没有args的装饰器),您可以这样称呼它:您实际上是将它封装在装饰器函数中,如下所示:
>>> foo = decorator(function)
'foo'注意,function没有被调用。如果装饰器和函数都有需要传递的参数,这将如何工作?
>>> foo = decorator_with_args(decorator(wrapped_function))但是,装饰器的*args和**kwargs以及最初的函数到哪里去了呢?
发布于 2018-10-20 18:37:01
decorator_with_args()是一个装饰工厂--也就是说,一个返回装饰器的函数。这意味着为了在不使用@语法的情况下使用它,需要使用它的参数调用它,然后使用函数作为参数调用结果。
这是怎么看的:
def function():
return 'foo'
function = decorator_with_args('arg1', 'arg2')(function)
>>> function()
'foo'请注意,这类似于使用带有或不使用@语法的常规装饰器之间的区别:
@deco
def func(arg):
# ...就是
def func(arg):
# ...
func = deco(func)作为
@deco_fac(x, y)
def func(arg):
# ...就是
def func(arg):
# ...
func = deco_fac(x, y)(func)https://stackoverflow.com/questions/52908813
复制相似问题