繁体   English   中英

根据正负值对 dataframe 列的值进行排序?

[英]Sort values of a dataframe column based on positive and negative values?

我的 df 列由 +ve 和 -ve 列组成。

       A          B
0      a           5
1      b         -13
2      c          15
3      d         -10

有没有办法整理 +ve 值升序和 -ve 值降序

       A          B
0      a           5
1      c          15
2      d         -10
3      b         -13

首先使用boolean indexing过滤,按DataFrame.sort_values和最后一个concat排序:

mask = df['B'].gt(0)
df = pd.concat([df[mask].sort_values('B'),
                df[~mask].sort_values('B', ascending=False)], ignore_index=True)
print (df)
   A   B
0  a   5
1  c  15
2  d -10
3  b -13

暂无
暂无

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

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