按第一行对 numpy 2d 数组进行排序,维护列

Joe*_*her 2 python arrays sorting numpy

在 python 中,我有一个形式为 numpy 的数组:

[4 8 2 0 5]
[3 1 6 8 1]
[2 2 6 0 3]
[9 7 6 7 8]
[5 8 1 1 4]
Run Code Online (Sandbox Code Playgroud)

我想按第一行的值从左到右按升序对其进行排序,同时保持列作为一个整体完整。实际数组的维度未指定,而且非常庞大,所以自己用 for 循环编写一些东西会变得非常慢。结果应该是:

[0 2 4 5 8]
[8 6 3 1 1]
[0 6 2 3 2]
[7 6 9 8 7]
[1 1 5 4 8]
Run Code Online (Sandbox Code Playgroud)

我可以使用 argsort 得到一个列索引正确排序的行向量,但不知道从那里开始实际构建新数组。

Max*_*axU 6

源数组:

In [215]: a
Out[215]:
array([[4, 8, 2, 0, 5],
       [3, 1, 6, 8, 1],
       [2, 2, 6, 0, 3],
       [9, 7, 6, 7, 8],
       [5, 8, 1, 1, 4]], dtype=int64)
Run Code Online (Sandbox Code Playgroud)

使用 Numpy 索引:

In [218]: a[:, a[0].argsort()]
Out[218]:
array([[0, 2, 4, 5, 8],
       [8, 6, 3, 1, 1],
       [0, 6, 2, 3, 2],
       [7, 6, 9, 8, 7],
       [1, 1, 5, 4, 8]], dtype=int64)
Run Code Online (Sandbox Code Playgroud)

使用熊猫:

In [212]: pd.DataFrame(a).sort_values(0, axis=1).values
Out[212]:
array([[0, 2, 4, 5, 8],
       [8, 6, 3, 1, 1],
       [0, 6, 2, 3, 2],
       [7, 6, 9, 8, 7],
       [1, 1, 5, 4, 8]], dtype=int64)
Run Code Online (Sandbox Code Playgroud)

  • @JoeGallagher,你不能使用 Numpy 对 Numpy 数组进行排序? (3认同)
  • 不,不能使用熊猫,我的回复是在您编辑之前做出的。Numpy 解决方案有效。 (2认同)