我对创建泛型函数并用它装饰所有其他函数感兴趣。新函数将包含两个函数的参数。示例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
这是我想出来的,但是。。。在
^{pr2}$
我使用**kwargs作为解释func参数的方法,但是由于**kwargs的位置,这迫使我使用func(var=“hi”,a=4,b=5),而不是func(a=4,b=5,var=“hi”)。在
另外,这种解决方法可以防止我在定义decorator时在需要时使用**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的测试函数)
感谢您的任何帮助,编码专家!在
编辑:
或者简单地说,有没有其他方法可以在decorator中不使用kwargs来修改func(a,b,c,d,e,…,**kwargs)?在