pandas :将多列汇总为一列,没有最后一列
- 作者: 傻妞也
- 来源: 51数据库
- 2022-10-21
问题描述
如果我有一个类似于这个的数据框
If I have a dataframe similar to this one
Apples Bananas Grapes Kiwis 2 3 nan 1 1 3 7 nan nan nan 2 3
我想添加这样的列
Apples Bananas Grapes Kiwis Fruit Total 2 3 nan 1 6 1 3 7 nan 11 nan nan 2 3 5
我猜你可以使用 df['Apples'] + df['Bananas'] 等等,但我的实际数据框比这大得多.我希望像 df['Fruit Total']=df[-4:-1].sum 这样的公式可以在一行代码中解决问题.然而这并没有奏效.有没有办法在不明确总结所有列的情况下做到这一点?
I guess you could use df['Apples'] + df['Bananas'] and so on, but my actual dataframe is much larger than this. I was hoping a formula like df['Fruit Total']=df[-4:-1].sum could do the trick in one line of code. That didn't work however. Is there any way to do it without explicitly summing up all columns?
推荐答案
可以先通过 iloc 然后是 sum:
You can first select by iloc and then sum:
df['Fruit Total']= df.iloc[:, -4:-1].sum(axis=1) print (df) Apples Bananas Grapes Kiwis Fruit Total 0 2.0 3.0 NaN 1.0 5.0 1 1.0 3.0 7.0 NaN 11.0 2 NaN NaN 2.0 3.0 2.0
所有列的总和使用:
df['Fruit Total']= df.sum(axis=1)
推荐阅读
热点文章
Discord.py(重写)on_member_update 无法正常工作
0
Discord.py 在 vc 中获取用户分钟数
0
discord.py 重写 |为我的命令出错
0
Discord.py rewrite 如何 DM 命令?
0
播放音频时,最后一部分被切断.如何解决这个问题?(discord.py)
0
在消息删除消息 Discord.py
0
如何使 discord.py 机器人私人/直接消息不是作者的人?
0
(Discord.py) 如何获取整个嵌入内容?
0
Discord bot 尽管获得了许可,但不能提及所有人
0
Discord.py discord.NotFound 异常
0
