【发布时间】:2013-09-14 21:53:49
【问题描述】:
我有兴趣创建一个通用函数并用它装饰所有其他函数。新函数将包含两个函数的参数。示例
def decorator(func):
Some chunk of code
@decorator
def func(a,b):
print a**2,b**2
return a**2,b**2
#Equivalent func of what I want out of the decorator
def equiv_func(a,b,var):
print var # I want to modify all decorated functions to accept a new
# argument and print it using "print var"
print a**2, b**2
return a**2, b**2
这是我想出来的,但是......
def decor(func):
def modify(var,**kwargs):
print var
x,y=func(**kwargs)
return x,y
return modify
@decor
def func(a,b):
print a**2,b**2
return a**2,b**2
>>> func(var="hi",a=4,b=5)
hi
16 25
我使用 **kwargs 来解释 func 的参数,但这迫使我使用 func(var="hi",a=4,b=5) 而不是 func(a=4,b= 5,var="hi") 由于 **kwargs 的定位。
此外,这种解决方法可以防止我在需要时定义装饰器时使用 **kwargs,因为它已经用于将参数输入到 func 中。示例
def test(**kwargs):
if 'test_ans' in kwargs:
if kwargs['test_ans']=='y':
return True
else:
return False
def decor(func):
def modify(var,**kwargs):
if test(**kwargs): # I need to use **kwargs here, but I also need it to define my
# arguments in func.
print var
x,y=func(**kwargs)
return x,y
return modify
...
# The following is what I expect but due to **kwargs being used for two purposes,
# it doesn't work
>>>func(var='hi',a=4,b=5,test_ans='y')
'hi'
16 25
>>>func(var='hi',a=4,b=5,test_ans='n')
16 25
我希望我的问题很清楚。这些例子只是为了说明我面临的限制。它们不是实际代码(例如,我不会编写使用 **kwargs 的测试函数) 提前感谢您的任何帮助,编码大师!
编辑: 或者简单地说,有没有其他方法可以在不使用装饰器中的kwargs的情况下将func(a,b)修改为func(a,b,c,d,e,...,**kwargs)?
【问题讨论】:
-
您可以拨打
func(a=4, b=5, var="hi")。 -
首先,同意falsetru 的评论。如果您命名所有参数,您可以以任何您喜欢的方式对它们进行排序。当您开始命名事物时,定位就会被抛出窗口。唯一的要求是函数/方法定义中的所有位置参数在每次调用函数/方法时都必须有一个参数传递给它们。你也可以在定义你的装饰器时使用
**kwargs...仅仅因为你在装饰器的内部函数中使用**kwargs并不意味着你不能也使用**kwargs作为装饰器本身。 -
同意。但问题在于 **kwargs。如果我输入的可选参数多于 func 所需的参数(但我需要额外的参数来决定装饰器的行为),我会得到一个 TypeError 因为参数多于 func 需要的参数。
标签: python arguments decorator