lambda是单表达式匿名函数,仅支持表达式而非语句,适用于map/filter/sorted等场景的简单逻辑,复杂逻辑应使用def。
Python 的 lambda 只能包含一个表达式,不能有语句(比如 return、if 块、for 循环),它的返回值就是该表达式的结果。很多人误以为它能替代任意函数,结果写到一半发现语法报错:SyntaxError: invalid syntax。
lambda x: x * 2 ✅ 合法 —— 表达式直接求值lambda x: return x * 2 ❌ 报错 —— return 是语句,不允许lambda x: if x > 0: x else 0 ❌ 报错 —— if 语句不行,但三元表达式可以:lambda x: x if x > 0 else 0 ✅lambda 调用,或直接用 def
当处理数据时需要临时定义“怎么算”“怎么留”“怎么排”,lambda 就是为这种场景设计的。它让代码更紧凑,且避免为一次性逻辑起名。
numbers = [3, 1, 4, 1, 5] # 按绝对值排序(原 list 不变) sorted(numbers, key=lambda x: abs(x - 3))words = ['apple', 'banana', 'cherry']
取每个单词长度大于 5 的
list(filter(lambda w: len(w) > 5, words))
平方后转为字符串
list(map(lambda x: str(x ** 2), numbers))
key= 参数必须是可调用对象,lambda 天然适配;用 abs 或 len 也行,但复杂逻辑只能靠 lambda 或自定义函数filter 的函数需返回布尔值,lambda w: len(w) > 5 直观清晰;写成 lambda w: bool(len(w) > 5) 完全多余map 和 filter 在 Python 3 中返回迭代器,要结果得套一层 list()
在循环中创建多个 lambda,它
们共享外部作用域的变量,容易全部指向最后一个循环值。这是新手高频踩坑点,报错不明显,但结果错得离谱。
funcs = []
for i in range(3):
funcs.append(lambda: i)
print([f() for f in funcs]) # 输出 [2, 2, 2],不是 [0, 1, 2]lambda 都引用了同一个变量 i,循环结束时 i == 2
lambda i=i: i
[lambda i=i: i for i in range(3)]
def 函数,可读性和调试性都更好超过 2 个参数、嵌套超过一层、或含复杂条件判断的 lambda,基本等于给自己埋雷。PEP 8 明确建议:如果 lambda 影响可读性,就用 def。
lambda x, y, z: (x + y) * z if x > 0 and y != z else max(x, y, z) // 2 —— 这已经不是“简洁”,是难维护lambda 的典型长度:1 行、≤ 3 个操作符、无嵌套逻辑lambda 在 traceback 中显示为 ,没有函数名,出错定位困难mock.patch('module.')
真正实用的 lambda,是让意图一目了然的那一小段计算逻辑;一旦开始缩进、换行、加注释,它就该退休了。