我有一个函数数组,我试图产生一个由数组中元素组成的函数。我的方法是:
def compose(list): if len(list) == 1: return lambda x:list[0](x) list.reverse() final=lambda x:x for f in list: final=lambda x:f(final(x)) return final
此方法似乎无效,将不胜感激。
(我要反转列表,因为这是我希望函数成为的组合顺序)
它不起作用,因为您在循环中创建的所有匿名函数都引用相同的循环变量,因此共享其最终值。
作为快速解决方案,您可以将分配替换为:
final = lambda x, f=f, final=final: f(final(x))
或者,您可以从函数返回lambda:
def wrap(accum, f): return lambda x: f(accum(x)) ... final = wrap(final, f)
要了解发生了什么,请尝试以下实验:
>>> l = [lambda: n for n in xrange(10)] >>> [f() for f in l] [9, 9, 9, 9, 9, 9, 9, 9, 9, 9]
这个结果使许多人感到惊讶,他们期望结果会如此[0, 1, 2, ...]。但是,所有的lambda都指向相同的n变量,并且都指向其最终值9。在您的情况下,final应该嵌套的所有版本最终都指向相同的f,甚至更糟的是,指向相同的变量。final。
[0, 1, 2, ...]
n
final
f