如何在 Pandas 中根据上一行的值条件增加新列并累加满足条件的值?

霞舞
发布: 2024-11-12 20:27:19
原创
891人浏览过

如何在 pandas 中根据上一行的值条件增加新列并累加满足条件的值?

根据上一行的值条件增加新列

在 pandas 中,可以通过 df.apply() 函数结合条件判断和赋值操作,根据上一行的值条件向 dataframe 中增加新列。

例如,给定一个 dataframe:

values = [[5.5, 2.5, 10.0], [2.0, 4.5, 1.0], [2.5, 5.2, 8.0], [4.5, 5.8, 4.8], [4.6, 6.3, 9.6], [4.1, 6.4, 9.0], [5.1, 2.3, 11.1]]
df = pd.dataframe(values, columns=['col1', 'col2', 'col3'],index=['a', 'b', 'c', 'd', 'e', 'f', 'g'])
登录后复制

要根据 col1 列的值条件向 dataframe 中增加新列 col4,满足条件 3 < col1 < 5 时 col4 为 1,否则为 0,可以使用以下代码:

Alkaid.art
Alkaid.art

专门为Phtoshop打造的AIGC绘画插件

Alkaid.art 153
查看详情 Alkaid.art
df['col4'] = df.apply(lambda x: 1 if 3 < x['col1'] < 5 else 0, axis=1)
登录后复制

结果为:

col1  col2  col3  col4
a   5.5   2.5  10.0    0
b   2.0   4.5   1.0    0
c   2.5   5.2   8.0    0
d   4.5   5.8   4.8    1
e   4.6   6.3   9.6    1
f   4.1   6.4   9.0    1
g   5.1   2.3  11.1    0
登录后复制

进一步,如果需要将满足条件 3 < col1 < 5 的 col4 值累加,可以进一步使用 cumsum() 方法:

df['col4'] = df['col4'].cumsum()
登录后复制

结果为:

col1  col2  col3  col4
a   5.5   2.5  10.0    0
b   2.0   4.5   1.0    0
c   2.5   5.2   8.0    0
d   4.5   5.8   4.8    1
e   4.6   6.3   9.6    2
f   4.1   6.4   9.0    3
g   5.1   2.3  11.1    3
登录后复制

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

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

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

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

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