下面的代码片段演示了嵌套的lambdas列表仅计算为原始lambdas列表的最后一个元素。
eqs_test = [
(lambda x: f"0"),
(lambda x: f"1"),
(lambda x: f"2"),
(lambda x: f"3"),
]
# unexpected output
print([a(1) for a in [
lambda x: f"{e1(0)}-{e2(0)}" for e1, e2 in zip(eqs_test[1:], eqs_test[:-1])
]])
# expected output (no outer lambda used here for testing)
print([a for a in [
f"{e1(0)}-{e2(0)}" for e1, e2 in zip(eqs_test[1:], eqs_test[:-1])
]])
输出为:
['3-2', '3-2', '3-2']
['1-0', '2-1', '3-2']
我希望在这两种情况下都会有第二个输出,但不知何故,lambda没有正确存储(3-2
只是最后生成的lambda)。这里发生了什么?我如何存储外部lambda,以便它运行正确的嵌套lambda?
发布于 2020-10-13 02:35:36
要使第一个示例工作,请将变量存储为lambda参数。否则,lambda将始终打印e1
和e2
的最后一个值:
eqs_test = [
(lambda x: f"0"),
(lambda x: f"1"),
(lambda x: f"2"),
(lambda x: f"3"),
]
# unexpected output
print([a(1) for a in [
lambda x, e1=e1, e2=e2: f"{e1(0)}-{e2(0)}" for e1, e2 in zip(eqs_test[1:], eqs_test[:-1])
]])
打印:
['1-0', '2-1', '3-2']
https://stackoverflow.com/questions/64323439
复制相似问题