繁体   English   中英

仅对数据框 Pandas 中各列的负数求和

[英]Sum only negative numbers across columns in dataframe Pandas

我只想对数据框中所有列的负数求和。

我看过这篇文章: Pandas:将多列汇总为一列

我的数据如下所示:

但我只想总结负数。 我怎么做?

使用mask

df.iloc[:,1:].where(df.iloc[:,1:]<0).sum(axis=1)

使用apply

df['Sum']=df.apply(lambda x: x[x<0].sum(),axis=1)

另一种方法是使用abs

df['neg_sum'] = df.where(df != df.abs()).sum(1)

我建议你避免apply ; 它可能会很慢。

这将起作用: df[df < 0].sum()

这是我的解决方案,根据我在引用问题中的回答进行了修改:

df = pd.DataFrame({'a': [-1,2,3], 'b': [-2,3,4], 'c':[-3,4,5]})

column_names = list(df.columns)
df['neg_sum']= df[df[column_names]<0].sum(axis=1)

此答案允许按名称选择确切的列,而不是采用所有列。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM