[英]Decorator/wrapper: How to deal with arguments after positional/keyword args are all assigned to wrapped function's parameters?
我想知道在Python中是否有一种方法可以让包装器在将函数的参数解析为参数后对其进行访问。 因此,例如,我想包装两个具有不同(数量)参数的函数:
def fn_1(a, b=None, config=None):
...
def fn_2(b=None, config=None):
...
我想对我的包装,看是否config
并具有价值,如果没有,从别的地方加载它:
class with_config(object):
def __init__(self, f):
self.f = f
def __call__(self, *args, **kwargs):
if config not in kwargs:
kwargs[config] = load_config_from_some_default_location()
但我不知道如何确定config
是否已按位置传递,因为它在args
列表中的位置因函数而异。
如果我已经根据参数给位置参数指定了名称(例如,将第一个位置分配给a
,将第二个位置分配给b
,第三个位置分配给config
),然后可以保留这些参数,那么我会答应。
情况比这要复杂得多,但是我认为这使我的问题更容易理解。
有小费吗?
这可以帮助您:
import inspect
def func(a, b=None, config=None):
args, _, _, values = inspect.getargvalues(inspect.currentframe())
print args # prints 'a', 'b', 'config'
print values # prints {'a':12, 'b':None, 'config':None}
if values['config'] == None:
# Load config from somewhere else
if __name__ == '__main__':
func(12)
我终于从Nadia Alramli那里得到了这个解决方案 :
class with_config(object): def
__init__
(self, f): self.f = f def __call__
(self, *args, **kwargs): kwargs.update(dict(zip(self.f.func_code.co_varnames, args))) if config not in kwargs: kwargs[config] = load_config_from_some_default_location() return self.f(**kwargs)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.