Python高阶函数使用_map与filter说明【指导】

24次阅读

mapFilterpython中用于批量转换和条件筛选的高阶函数,map一对一映射,filter按布尔判断过滤,二者惰性求值、不修改原数据,常组合使用且语义清晰。

Python高阶函数使用_map与filter说明【指导】

Python 中的 mapfilter 是两个最常用、最典型的高阶函数,它们接受函数作为参数,对可迭代对象进行转换或筛选,代码简洁且语义清晰。

map:对每个元素执行相同操作

map(func, iterable) 将函数 func 应用到 iterable 的每一个元素上,返回一个 map 对象(惰性求值,需转为 list 等类型才可见结果)。

  • 适合做“批量转换”,比如字符串转小写、数字平方、列表元素类型统一转换
  • 函数可以是内置函数(如 strlen)、自定义函数,或 Lambda 表达式
  • 注意:map 不改变原数据,也不过滤,只做一对一映射

示例:
# 将数字列表全部平方
nums = [1, 2, 3, 4]
squares = list(map(lambda x: x ** 2, nums))
print(squares) # [1, 4, 9, 16]

filter:按条件保留符合条件的元素

filter(func, iterable) 用函数 func 判断每个元素是否为真(True),只保留返回 True 的元素,同样返回惰性 filter 对象。

立即学习Python免费学习笔记(深入)”;

  • func 应该是一个“判断函数”,返回布尔值;返回 None 时等价于 bool(x)
  • 常用于清洗数据,比如剔除空字符串、筛选正数、保留偶数等
  • 和 list 推导式功能相近,但 filter 更强调“逻辑判断”的意图

示例:
# 只保留大于 0 的数
data = [-2, -1, 0, 1, 2, 3]
positives = list(filter(lambda x: x > 0, data))
print(positives) # [1, 2, 3]

map + filter 组合使用更自然

实际处理中,常先用 filter 筛选有效数据,再用 map 转换格式,逻辑清晰、职责分明。

  • 避免在一个 lambda 里混杂判断和转换逻辑
  • 组合后仍保持惰性,性能友好;必要时再转 list 或用 for 遍历
  • 比嵌套推导式更易读,尤其当处理步骤较多时

示例:
# 提取非空字符串,并转为大写
words = [“hello”, “”, “world”, None, “python“]
valid_upper = list(map(str.upper, filter(lambda s: s and isinstance(s, str), words)))
print(valid_upper) # [‘HELLO’, ‘WORLD’, ‘PYTHON’]

注意事项与替代建议

虽然 map/filter 简洁,但要注意适用场景:

  • 简单操作优先考虑 list 推导式,可读性往往更高(如 [x**2 for x in nums]
  • func 若有副作用(如修改全局变量、打印日志),不推荐用 map —— 它本意是纯函数式转换
  • Python 3 中 map/filter 返回迭代器,多次使用需重新调用或转为 list/tuple
  • 复杂逻辑建议拆成独立函数,而非塞进 lambda,便于测试和复用
text=ZqhQzanResources