当前位置: 首页 > news >正文

【Python 中 lambda、map、filter 和 reduce】详细功能介绍及用法总结

以下是 Python 中 lambdamapfilterreduce 的详细功能介绍及用法总结,涵盖基础语法、高频场景和示例代码。


一、lambda 匿名函数

功能

  • 用于快速定义一次性使用的匿名函数。
  • 不需要显式命名,适合简化小规模逻辑。

语法

lambda 参数1, 参数2, ...: 表达式

示例

# 定义加法函数
add = lambda a, b: a + b
print(add(3, 5))  # 输出 8# 作为参数传递给其他高阶函数
squared = map(lambda x: x**2, [1, 2, 3])
print(list(squared))  # 输出 [1, 4, 9]

二、map 映射

功能

  • 对序列中的每个元素执行指定操作,生成新的迭代器。

语法

map(函数, 可迭代对象)

示例

# 将列表中的每个数平方
numbers = [1, 2, 3, 4]
result = map(lambda x: x**2, numbers)
print(list(result))  # 输出 [1, 4, 9, 16]# 处理多序列(按最短序列长度)
texts = ["apple", "banana", "cherry"]
sizes = [5, 6]
result = map(lambda a, b: (a, len(a), b), texts, sizes)
print(list(result))  # 输出 [('apple',5,5), ('banana',6,6)]

三、filter 过滤

功能

  • 根据条件筛选序列中满足要求的元素,生成新的迭代器。

语法

filter(条件函数, 可迭代对象)

示例

# 过滤偶数
numbers = [1, 2, 3, 4, 5, 6]
even = filter(lambda x: x % 2 == 0, numbers)
print(list(even))  # 输出 [2, 4, 6]# 过滤非空字符串
words = ["hello", "", "world", None, " "]
valid_words = filter(lambda s: s and s.strip(), words)
print(list(valid_words))  # 输出 ['hello', 'world']

四、reduce 累积

功能

  • 将序列中的元素通过函数累积计算,最终返回一个结果(需导入 functools 模块)。

语法

from functools import reduce
reduce(累积函数, 可迭代对象, [初始值])

示例

from functools import reduce# 累加元素
numbers = [1, 2, 3, 4]
sum_result = reduce(lambda a, b: a + b, numbers)  # 等效于 1+2+3+4
print(sum_result)  # 输出 10# 求最大值
max_result = reduce(lambda a, b: a if a > b else b, numbers)
print(max_result)  # 输出 4# 字符串拼接
words = ["I", "love", "Python"]
sentence = reduce(lambda a, b: f"{a} {b}", words)
print(sentence)  # 输出 "I love Python"# 带初始值
product = reduce(lambda a, b: a * b, [2, 3, 4], 1)  # 1*2*3*4=24
print(product)  # 输出 24

五、实际应用场景

1. 数据清洗(filter + lambda

data = ["10.5", "error", "20.3", "NaN", "15.7"]# 过滤无法转换为浮点数的元素
clean_data = list(filter(lambda x: x.replace('.', '', 1).isdigit(), data))
print(clean_data)  # 输出 ['10.5', '20.3', '15.7']

2. 多条件转换(map + lambda

prices = [100, 200, 300]# 根据价格生成带税结果(税率 8%)
taxed_prices = list(map(lambda p: (p, p * 1.08), prices))
print(taxed_prices)  # 输出 [(100,108.0), (200,216.0), (300,324.0)]

3. 复杂累积(reduce

# 将二维列表扁平化
nested_list = [[1, 2], [3, 4], [5, 6]]
flattened = reduce(lambda a, b: a + b, nested_list)
print(flattened)  # 输出 [1, 2, 3, 4, 5, 6]

六、对比列表推导式

方法用途优点缺点
map + lambda统一处理每个元素简洁,适合小规模操作难以处理复杂逻辑
列表推导式生成新列表直观,支持条件分支大量计算时内存占用可能较高
filter + lambda筛选元素直接表达过滤条件多条件筛选语法稍复杂
生成器表达式惰性计算大数据内存高效,支持流式处理结果只能遍历一次

七、注意事项

  1. 可读性优先:如果逻辑复杂,建议使用显式命名的普通函数。
  2. 性能权衡map/filter 在大型数据集下可能比列表推导式更高效(尤其是结合生成器时)。
  3. Python 3 的迭代器mapfilter 返回迭代器,直接打印时需转换为列表(如 list(map(...)))。
  4. reduce 替代方案:简单累加建议使用 sum()max() 等内置函数。

掌握这些工具后,可以大幅简化迭代操作代码!建议优先使用列表推导式生成器表达式,必要时结合 lambdamapfilterreduce

http://www.xdnf.cn/news/621397.html

相关文章:

  • Java三十而立:Java 的30岁与Spring AI 1.0正式发布
  • STC89C52RC/LE52RC
  • 嵌入式Openharmony系统应用开发与实现方法
  • (已开源-CVPR2024) RadarDistill---NuScenes数据集Radar检测第一名
  • TypeScript 和 JavaScript核心关系及区别
  • 最大似然估计(Maximum Likelihood Estimation, MLE)详解
  • 机器学习课程设计报告 —— 基于二分类的岩石与金属识别模型
  • PHP SPL 自动加载机制详解与实战应用:spl_autoload_register 使用指南
  • BLIP论文笔记
  • 使用 CodeBuddy 实现视频合并工具:解决本地视频处理痛点
  • 【RabbitMQ运维】集群搭建
  • 【强化学习】#7 基于表格型方法的规划和学习
  • 力扣 283.移动零 (双指针)
  • SQL语句的执行流程
  • C++搜索二叉树
  • Java语言快速排序和堆排序(优先队列)介绍,附demo代码
  • C# 深入理解类(析构函数和this关键字)
  • 【RK3588新品】嵌入式人工智能实验箱EDU-AIoT ELF 2发布
  • 【萤火工场GD32VW553-IOT开发板】ADC电压的LabVIEW采集
  • 【漫话机器学习系列】275.GrabCut 算法——用于去除图片背景(Grabcut For Removing Image Backgrounds)
  • SpringBoot项目配置文件、yml配置文件
  • 大厂缓存架构方案-Caffeine+Redis双层缓存架构
  • 织梦dedecms登录后台出现Safe Alert Request Error step 2
  • 企业级单元测试流程
  • BLIP3-o:一系列完全开源的统一多模态模型——架构、训练与数据集
  • 深入理解 JVM 运行时数据区
  • 让MySQL更快:EXPLAIN语句详尽解析
  • 如何设计Agent的记忆系统
  • Cmake编译gflags过程记录和在QT中测试
  • std::thread的说明与示例