在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]
我希望按照从左到右的第一行的值按升序对其进行排序,同时保持列整体完整。实际的数组具有未指定的维度,并且非常巨大,因此使用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]
我可以使用argsort获得一个行向量,其列索引正确排序,但在实际构建新数组时不知道从那里开始。
答案 0 :(得分:3)
源数组:
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)
使用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)
使用熊猫:
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)