0

0

Python中如何计算数据累积和?cumsum函数详解

蓮花仙者

蓮花仙者

发布时间:2025-07-12 14:22:01

|

787人浏览过

|

来源于php中文网

原创

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中如何计算数据累积和?cumsum函数详解

Python中计算数据累积和,最常用也最便捷的方式就是利用NumPy库的cumsum函数,或者在处理表格数据时,使用Pandas库的DataFrameSeries对象自带的cumsum方法。它们能高效地对数组或序列中的元素进行逐个累加,并返回一个新数组或序列,其中每个元素是原数组从开头到当前位置所有元素的总和。

Python中如何计算数据累积和?cumsum函数详解

解决方案

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

使用NumPy的cumsum

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

Python中如何计算数据累积和?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

Python中如何计算数据累积和?cumsum函数详解

Pandas的SeriesDataFrame对象也内置了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默认会把它们一路“传染”下去,这在某些场景下是合理的,但有时你可能希望跳过。而分组累积求和,这简直是数据分析的“瑞士之刃”,尤其在处理时间序列或者分类数据时,它能帮你快速看到每个组内部的累积趋势。

人民网AIGC-X
人民网AIGC-X

国内科研机构联合推出的AI生成内容检测工具

下载

处理缺失值(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是标准答案,但在某些特殊情况下,或者仅仅是为了理解其工作原理,你可能会遇到或考虑其他方法。

  1. 纯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)
  2. 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才可能成为一个有益的补充。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C语言变量命名
C语言变量命名

c语言变量名规则是:1、变量名以英文字母开头;2、变量名中的字母是区分大小写的;3、变量名不能是关键字;4、变量名中不能包含空格、标点符号和类型说明符。php中文网还提供c语言变量的相关下载、相关课程等内容,供大家免费下载使用。

410

2023.06.20

c语言入门自学零基础
c语言入门自学零基础

C语言是当代人学习及生活中的必备基础知识,应用十分广泛,本专题为大家c语言入门自学零基础的相关文章,以及相关课程,感兴趣的朋友千万不要错过了。

637

2023.07.25

c语言运算符的优先级顺序
c语言运算符的优先级顺序

c语言运算符的优先级顺序是括号运算符 > 一元运算符 > 算术运算符 > 移位运算符 > 关系运算符 > 位运算符 > 逻辑运算符 > 赋值运算符 > 逗号运算符。本专题为大家提供c语言运算符相关的各种文章、以及下载和课程。

362

2023.08.02

c语言数据结构
c语言数据结构

数据结构是指将数据按照一定的方式组织和存储的方法。它是计算机科学中的重要概念,用来描述和解决实际问题中的数据组织和处理问题。数据结构可以分为线性结构和非线性结构。线性结构包括数组、链表、堆栈和队列等,而非线性结构包括树和图等。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

263

2023.08.09

c语言random函数用法
c语言random函数用法

c语言random函数用法:1、random.random,随机生成(0,1)之间的浮点数;2、random.randint,随机生成在范围之内的整数,两个参数分别表示上限和下限;3、random.randrange,在指定范围内,按指定基数递增的集合中获得一个随机数;4、random.choice,从序列中随机抽选一个数;5、random.shuffle,随机排序。

629

2023.09.05

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

c语言get函数的用法
c语言get函数的用法

get函数是一个用于从输入流中获取字符的函数。可以从键盘、文件或其他输入设备中读取字符,并将其存储在指定的变量中。本文介绍了get函数的用法以及一些相关的注意事项。希望这篇文章能够帮助你更好地理解和使用get函数 。

669

2023.09.20

c数组初始化的方法
c数组初始化的方法

c语言数组初始化的方法有直接赋值法、不完全初始化法、省略数组长度法和二维数组初始化法。详细介绍:1、直接赋值法,这种方法可以直接将数组的值进行初始化;2、不完全初始化法,。这种方法可以在一定程度上节省内存空间;3、省略数组长度法,这种方法可以让编译器自动计算数组的长度;4、二维数组初始化法等等。

618

2023.09.22

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号