Python的map和filter是不改变原数据、返回新迭代器的高阶函数,map用于统一变换元素,filter用于按条件筛选元素,二者常组合使用且可与列表推导式互换,选择取决于函数复用性与逻辑复杂度。
Python的map和filter是两个常用高阶函数,它们不改变原数据,而是返回新迭代器,适合函数式编程风格。用好它们能写出更简洁、可读性更强的代码。
map(func, iterable)把函数func依次作用于iterable中每个元素,返回一个map对象(需转为list等类型才能查看)。
str、abs)、lambda表达式或自定义函数map或转成列表示例:
>>> list(map(lambda x: x ** 2, [1, 2, 3, 4]))
[1, 4, 9, 16]
filter(func, iterable)用函数func判断每个元素是否保留——返回True的留下,False的丢弃,同样返回惰性迭代器。
None时,自动过滤掉所有“假值”(如0、''、None、[]等)示例:
>>> list(filter(lambda x: x > 0, [-2, -1, 0, 1, 2]))
[1, 2]
先筛选再变换,或先变换再筛选,链式逻辑自然。虽然不能直接连写(因返回迭代器),但嵌套调用或分步赋值都很直观。
list(filter(..., map(...)))超过两层建议拆开map(int, ...)前最好先filter(str.isdigit, ...)
示例:
>>> nums = ['1', 'abc', '2', '', '3']
>>> valid_nums = filter(str.isdigit, nums)
>>> result = list(map(int, valid_nums))
[1, 2, 3]
map和filter强调“函数应用”,列表推导式强调“结构化生成”。两者功能常重叠,选择看场景:
len、str.upper)→ 优先map/filter,更简洁map(filter(...))更直白例如:
# 等价写法
list(map(str.uppe
r, filter(lambda x: len(x) > 2, words)))
# 更推荐:
[x.upper() for x in words if len(x) > 2]