我想使用functools中的partial来部分应用函数的第二个参数,我知道使用lambda很容易,而不是部分如下
>>> def func1(a,b):
... return a/b
...
>>> func2 = lambda x:func1(x,2)
>>> func2(4)
2
但我非常想在这里使用partial(为了学习)所以我想出了这个。
>>> def swap_binary_args(func):
... return lambda x,y: func(y,x)
...
>>> func3 = partial(swap_binary_args(func1),2)
>>> func3(4)
2
是否可以将此策略扩展到我可以在任何地方部分应用任何参数的级别,如下面的伪代码
>>>def indexed_partial(func, list_of_index, *args):
... ###do_something###
... return partially_applied_function
>>>func5=indexed_partial(func1, [1,4,3,5], 2,4,5,6)
在我们的例子中,我可以使用如下函数
>>>func6=indexed_partial(func1, [1], 2)
是否有可能像我想要的索引部分?我有什么类似的东西,我不知道吗?更重要的是索引部分的想法通常是一个好的或坏的想法为什么?
此问题已标记为Can one partially apply the second argument of a function that takes no keyword arguments?可能重复 在那个问题上,OP问是否有可能部分应用第二个参数但在这里我问的是如何烹饪一个可以部分应用任意参数的函数
答案 0 :(得分:1)
我也认为你的问题不能用functools.partial
完成(轻松?)。可能最好(也是最可读)的解决方案是使用带有关键字参数的partial
。
但是,如果您想使用位置参数(以及索引的部分参数),这里有indexed_partial
的可能定义:
def indexed_partial(func, list_of_index, *args):
def partially_applied_function(*fargs, **fkwargs):
nargs = len(args) + len(fargs)
iargs = iter(args)
ifargs = iter(fargs)
posargs = ((ifargs, iargs)[i in list_of_index].next() for i in range(nargs))
return func(*posargs, **fkwargs)
return partially_applied_function