让DataFrame中的行按照某一列元素的绝对值从大到小排列

  统计/机器学习 数据预处理 Python    浏览次数: 796
1

对于pandas.DataFrame,我想让这个df中的行按照某一列,比如说col_a中元素的绝对值的大小,从大到小排列,该怎么操作?

 

道画师   2017-03-27 12:36



   1个回答 
5

假如你的pd.DataFrame是df,你想按照col_1中的数值对df重新排列

降序排列(从大到小)

df.reindex(df['col_1'].abs().sort_values(ascending=False).index)

升序排列(从小到大)

df.reindex(df['col_1'].abs().sort_values(ascending=True).index)


>>> df
   col_1  col_2
0      2      1
1      4      3
2     -3      5
3     -5      7

>>> df.reindex(df['col_1'].abs().sort_values(ascending=False).index)
   col_1  col_2
3     -5      7
1      4      3
2     -3      5
0      2      1



派大星   2017-03-28 10:13



  相关主题

python的dataframe如何重新排列行或者列   1回答

怎么求一个数组的移动平均数   1回答

在数据预处理阶段,特征的标准化有哪些方法?   1回答

dummy variable是n个还是n-1个   2回答

对于数值型变量模型怎么知道是连续变量还是离散变量?   2回答

数据一样,y却不一样的样本该怎么处理?   2回答

对进行回归分析之前,如何处理不同类型的变量?   1回答

线性回归的变量归一化的问题   1回答

训练集中重复的样本需要被删除吗?   3回答

sklearn OneHotEncoder string类型报错   1回答

对pandas.DataFrame进行groupby结果中index的问题   2回答

pandas怎么读入tsv格式的数据   1回答



回答问题时需要注意什么?

我们谢绝在回答前讲“生动”的故事。

我们谢绝“这么简单,你自己想”、“书上有的,你认真看”这类的回答;如果你认为对方的提问方式或者内容不妥,你可以直接忽略该问题,不用进行任何作答,甚至可以对该问题投反对票。

我们谢绝答非所问。

我们谢绝自己不会、硬要回答。

我们感激每一个用户在编写答案时的努力与付出!