Pandas DataFrame如何根据上一行值条件累加生成新列?

花韻仙語
发布: 2025-03-18 09:04:01
原创
351人浏览过

利用pandas高效累加生成dataframe新列

本文介绍如何使用Python的Pandas库,根据DataFrame中现有列的值,创建一个新的列,并基于特定条件进行累加计数。 我们将以一个包含'col1'、'col2'、'col3'三列的DataFrame为例,创建一个新的'col4'列。当'col1'列的值介于3和5之间(不包含3和5)时,'col4'列的值累加计数;否则为0。

Pandas DataFrame如何根据上一行值条件累加生成新列?

直接使用df.apply和lambda函数虽然可以判断条件,但难以实现累加。 更有效的方法是结合np.where、cumsum()和fillna()函数。 np.where根据条件生成一个包含1(满足条件)和NaN(不满足条件)的Series;cumsum()对该Series进行累加;fillna(0)将NaN替换为0。 这种方法简洁高效。

代码示例:

import pandas as pd
import numpy as np

# 示例DataFrame (请替换为您的实际数据)
data = {'col1': [1, 4, 2, 4.5, 6, 4, 3.5], 
        'col2': [10, 20, 30, 40, 50, 60, 70], 
        'col3': [100, 200, 300, 400, 500, 600, 700]}
df = pd.DataFrame(data)

df['col4'] = pd.Series(np.where((df['col1'] > 3) & (df['col1'] < 5), 1, np.nan)).cumsum().fillna(0)

print(df)
登录后复制

虽然循环迭代或自定义函数结合df.apply也能实现,但效率较低且代码冗余。 因此,推荐使用np.where、cumsum()和fillna()的组合,因为它简洁、高效且易于理解。 此方法可轻松根据上一行值条件在Pandas DataFrame中新增列并进行累加计数。

以上就是Pandas DataFrame如何根据上一行值条件累加生成新列?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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