Pythoncumsum函数详解与使用方法
目前golang学习网上已经有很多关于文章的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《Python中cumsum函数使用教程》,也希望能帮助到大家,如果阅读完后真的对你学习文章有帮助,欢迎动动手指,评论留言并分享~
在Python中计算数据累积和,最常用的方法是使用NumPy的cumsum函数或Pandas的cumsum方法。1. NumPy的cumsum支持多维数组操作,默认展平数组进行累加,也可通过axis参数指定轴向,如axis=0按列累加、axis=1按行累加;2. Pandas的cumsum适用于Series和DataFrame,保留索引与列名,便于表格数据分析,并支持skipna参数处理缺失值及groupby结合实现分组累积求和;3. 性能方面,NumPy和Pandas的cumsum基于C语言实现,高效稳定,是首选方案,仅在特定简单场景下可考虑itertools.accumulate等替代方式。
Python中计算数据累积和,最常用也最便捷的方式就是利用NumPy库的cumsum
函数,或者在处理表格数据时,使用Pandas库的DataFrame
或Series
对象自带的cumsum
方法。它们能高效地对数组或序列中的元素进行逐个累加,并返回一个新数组或序列,其中每个元素是原数组从开头到当前位置所有元素的总和。

解决方案
在Python中,要实现数据的累积和计算,NumPy和Pandas库提供了极其方便且高效的cumsum
函数。这几乎是我在数据分析工作中处理序列累加时,不假思索就会选择的方法。
使用NumPy的cumsum
:

NumPy的ndarray
对象本身就支持cumsum
方法,或者你可以直接调用numpy.cumsum()
函数。它会沿着指定的轴(默认为展平后的数组)计算累积和。
import numpy as np # 1D数组的累积和 data_1d = np.array([1, 2, 3, 4, 5]) cumulative_sum_1d = np.cumsum(data_1d) print("1D数组累积和:", cumulative_sum_1d) # 输出: 1D数组累积和: [ 1 3 6 10 15] # 2D数组的累积和(默认展平) data_2d = np.array([[1, 2], [3, 4]]) cumulative_sum_2d_flat = np.cumsum(data_2d) print("2D数组展平后累积和:", cumulative_sum_2d_flat) # 输出: 2D数组展平后累积和: [ 1 3 6 10]
使用Pandas的cumsum
:

Pandas的Series
和DataFrame
对象也内置了cumsum
方法,这在处理表格数据时尤为方便。它能自动保留索引和列名,让结果更具可读性。
import pandas as pd # Series的累积和 s = pd.Series([10, 20, 30, 40, 50]) cumulative_sum_s = s.cumsum() print("\nSeries累积和:\n", cumulative_sum_s) # 输出: # Series累积和: # 0 10 # 1 30 # 2 60 # 3 100 # 4 150 # dtype: int64 # DataFrame的累积和(默认按列,即axis=0) df = pd.DataFrame({ 'A': [1, 2, 3], 'B': [10, 20, 30], 'C': [100, 200, 300] }) cumulative_sum_df_col = df.cumsum() print("\nDataFrame按列累积和:\n", cumulative_sum_df_col) # 输出: # DataFrame按列累积和: # A B C # 0 1 10 100 # 1 3 30 300 # 2 6 60 600
这两种方法,无论是面对简单的数字序列,还是复杂的多维数据表,都能提供高效且直观的累积和计算能力。
NumPy cumsum
函数在多维数组中的应用与轴向理解
我刚开始接触NumPy的axis
参数时,确实有点绕,感觉它总是在玩“反直觉”的游戏。但一旦你理解了,axis
其实就是指操作发生时,哪个维度会被“压缩”或者说“遍历”掉。对于多维数组,numpy.cumsum()
的axis
参数决定了累积和是按行计算还是按列计算,这在处理表格数据或图像数据时尤为关键。
axis=0
:沿着第一个轴(行)进行计算,结果的每一列是原数组对应列的累积和。可以理解为“向下”累加。axis=1
:沿着第二个轴(列)进行计算,结果的每一行是原数组对应行的累积和。可以理解为“向右”累加。
import numpy as np data_2d = np.array([ [1, 2, 3], [4, 5, 6], [7, 8, 9] ]) print("原始2D数组:\n", data_2d) # 沿着axis=0(列方向)累积求和 cumsum_axis_0 = np.cumsum(data_2d, axis=0) print("\n沿着axis=0累积和(按列累加):\n", cumsum_axis_0) # 解释: # 第1列: [1, 1+4, 1+4+7] = [1, 5, 12] # 第2列: [2, 2+5, 2+5+8] = [2, 7, 15] # 第3列: [3, 3+6, 3+6+9] = [3, 9, 18] # 沿着axis=1(行方向)累积求和 cumsum_axis_1 = np.cumsum(data_2d, axis=1) print("\n沿着axis=1累积和(按行累加):\n", cumsum_axis_1) # 解释: # 第1行: [1, 1+2, 1+2+3] = [1, 3, 6] # 第2行: [4, 4+5, 4+5+6] = [4, 9, 15] # 第3行: [7, 7+8, 7+8+9] = [7, 15, 24]
在实际应用中,比如你有一个记录了每天不同产品销售额的表格,如果想看每天每种产品的累计销售额,可能就需要axis=0
。而如果你想看每天所有产品销售额的累计总和,那可能就需要先对行求和,再进行累积,或者考虑更复杂的聚合方式。理解这个轴向,是掌握NumPy多维操作的关键一步。
Pandas cumsum
处理缺失值与分组累积求和的策略
很多时候,数据里总有那么些“空洞”,NaN
就是其中之一。cumsum
默认会把它们一路“传染”下去,这在某些场景下是合理的,但有时你可能希望跳过。而分组累积求和,这简直是数据分析的“瑞士之刃”,尤其在处理时间序列或者分类数据时,它能帮你快速看到每个组内部的累积趋势。
处理缺失值(NaN
):
Pandas的cumsum
方法有一个skipna
参数,默认是True
,表示在计算过程中会跳过NaN
值,并将NaN
视为0进行累加,但结果中仍然保留NaN
的位置。如果设置为False
,那么遇到NaN
后,后续的累积和都将是NaN
。
import pandas as pd import numpy as np s_with_nan = pd.Series([10, 20, np.nan, 30, 40]) print("原始Series(含NaN):\n", s_with_nan) # skipna=True (默认行为): 跳过NaN,但NaN位置仍为NaN cumsum_skipna_true = s_with_nan.cumsum(skipna=True) print("\ncumsum(skipna=True):\n", cumsum_skipna_true) # 解释:NaN位置依然是NaN,但后续的30是基于20累加的,而不是基于NaN。 # skipna=False: 遇到NaN后,后续都变为NaN cumsum_skipna_false = s_with_nan.cumsum(skipna=False) print("\ncumsum(skipna=False):\n", cumsum_skipna_false) # 解释:一旦遇到NaN,累积过程就中断,后续都变成了NaN。
分组累积求和:
这是Pandas中非常强大的一个功能组合,通过groupby()
方法结合cumsum()
,可以实现对数据按某个或多个类别进行分组后,再在每个组内独立进行累积和计算。
import pandas as pd data = { 'Category': ['A', 'A', 'B', 'A', 'B', 'A', 'B'], 'Value': [10, 5, 15, 8, 12, 3, 20] } df = pd.DataFrame(data) print("原始DataFrame:\n", df) # 按Category分组后,对Value进行组内累积求和 df['Cumulative_Value_Per_Category'] = df.groupby('Category')['Value'].cumsum() print("\n按Category分组后的累积和:\n", df) # 解释: # Category A: [10, 10+5, (跳过B), 15+8, (跳过B), 23+3] -> [10, 15, NaN, 23, NaN, 26, NaN] (索引对应) # Category B: [(跳过A), (跳过A), 15, (跳过A), 15+12, (跳过A), 27+20] -> [NaN, NaN, 15, NaN, 27, NaN, 47] (索引对应)
这种分组累积求和在分析销售数据(按产品类别累计)、用户行为(按用户ID累计登录时长)或财务报表(按部门累计支出)等场景中,都表现得极其高效和实用。
Python中累积和计算的性能考量与替代方案(在特定场景下)
我总觉得,当你开始考虑性能的时候,说明你处理的数据量已经不小了。cumsum
在Python生态里,尤其是NumPy和Pandas的版本,基本就是最优解了。它们底层都是用C语言实现的,因此对于大型数组或DataFrame,其执行效率非常高,通常不需要我们去手动优化。
为什么cumsum
是首选?
- 高度优化: NumPy和Pandas的
cumsum
函数都是用C语言编写的,这意味着它们执行速度极快,远超纯Python循环。 - 内存效率: 它们能够有效地处理大型数据集,而不会导致不必要的内存开销。
- 功能全面: 支持多维数组、缺失值处理、轴向控制等,功能强大。
一些“替代方案”或“理解性”的实现(在特定场景下):
虽然cumsum
是标准答案,但在某些特殊情况下,或者仅仅是为了理解其工作原理,你可能会遇到或考虑其他方法。
纯Python循环(仅用于理解,不推荐用于性能敏感场景): 这是最直观的实现方式,但性能极差,尤其是在数据量大时。
data = [1, 2, 3, 4, 5] cumulative_sum_py = [] current_sum = 0 for x in data: current_sum += x cumulative_sum_py.append(current_sum) print("纯Python循环累积和:", cumulative_sum_py)
itertools.accumulate
(适用于迭代器和内存敏感场景):itertools
模块提供了很多用于迭代器的工具,accumulate
就是其中之一。它返回一个迭代器,按需生成累积和,这在处理非常大的序列时可能比一次性加载到内存更节省资源,因为它不需要一次性创建整个结果列表。from itertools import accumulate data = [1, 2, 3, 4, 5] cumulative_sum_itertools = list(accumulate(data)) print("itertools.accumulate累积和:", cumulative_sum_itertools) # 也可以指定一个二元操作函数,例如累积乘积 import operator cumulative_product = list(accumulate(data, operator.mul)) print("itertools.accumulate累积乘积:", cumulative_product)
itertools.accumulate
的优点在于它的“惰性”计算和内存效率,它更适合处理流式数据或当你不需要一次性获得所有结果,而是逐个处理时。但它不如NumPy/Pandas那样直接支持多维数组的轴向操作或DataFrame的复杂索引结构。
总而言之,在Python中进行数据累积和计算,NumPy和Pandas的cumsum
函数几乎总是你的首选。它们在性能、功能和易用性之间找到了完美的平衡。只有在非常特殊、对内存极致敏感且数据结构简单的场景下,itertools.accumulate
才可能成为一个有益的补充。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Pythoncumsum函数详解与使用方法》文章吧,也可关注golang学习网公众号了解相关技术文章。

- 上一篇
- PyCharm默认存储位置解析指南

- 下一篇
- Linux系统安全加固方法详解
-
- 文章 · python教程 | 1小时前 |
- Python列表引用与循环内存解析
- 332浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Django框架入门:PythonWeb开发教程
- 208浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python环境配置步骤与设置指南
- 315浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python发邮件教程:smtplib使用全解析
- 218浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python中int类型详解及使用方法
- 473浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Pythondatetime处理时间全攻略
- 424浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Python面试题大全及常见问题解答
- 185浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Python中d是整数格式化占位符
- 243浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 畅图AI
- 探索畅图AI:领先的AI原生图表工具,告别绘图门槛。AI智能生成思维导图、流程图等多种图表,支持多模态解析、智能转换与高效团队协作。免费试用,提升效率!
- 18次使用
-
- TextIn智能文字识别平台
- TextIn智能文字识别平台,提供OCR、文档解析及NLP技术,实现文档采集、分类、信息抽取及智能审核全流程自动化。降低90%人工审核成本,提升企业效率。
- 24次使用
-
- 简篇AI排版
- SEO 简篇 AI 排版,一款强大的 AI 图文排版工具,3 秒生成专业文章。智能排版、AI 对话优化,支持工作汇报、家校通知等数百场景。会员畅享海量素材、专属客服,多格式导出,一键分享。
- 23次使用
-
- 小墨鹰AI快排
- SEO 小墨鹰 AI 快排,新媒体运营必备!30 秒自动完成公众号图文排版,更有 AI 写作助手、图片去水印等功能。海量素材模板,一键秒刷,提升运营效率!
- 19次使用
-
- Aifooler
- AI Fooler是一款免费在线AI音频处理工具,无需注册安装,即可快速实现人声分离、伴奏提取。适用于音乐编辑、视频制作、练唱素材等场景,提升音频创作效率。
- 25次使用
-
- Flask框架安装技巧:让你的开发更高效
- 2024-01-03 501浏览
-
- Django框架中的并发处理技巧
- 2024-01-22 501浏览
-
- 提升Python包下载速度的方法——正确配置pip的国内源
- 2024-01-17 501浏览
-
- Python与C++:哪个编程语言更适合初学者?
- 2024-03-25 501浏览
-
- 品牌建设技巧
- 2024-04-06 501浏览