http://blog.csdn.net/william_2015/article/details/47834889
数据准备
import numpy as np
from pandas import DataFrame
a=np.array([[1,0,6],[1,7,0],[2,4,0],[2,3,1]])
print (a)
[[1 0 6]
[1 7 0]
[2 4 0]
[2 3 1]]
我们的目标是按第 3 列升序排序,在此基础上,在按第 1 列降序排序,即得到如下效果:
[[2, 4, 0],
[1, 7, 0],
[2, 3, 1],
[1, 0, 6]]
numpy 实现
numpy 中的 numpy.argsort()
和 numpy.lexsort()
可以返回升序排序后的索引,不同的是numpy.lexsort()
可以接受多列,即可以进行子排序.
idex=np.lexsort([-1*a[:,0],a[:,2]])
a_sort=a[idex,:]
print (a_sort)
[[2 4 0]
[1 7 0]
[2 3 1]
[1 0 6]]
要注意的是 numpy.lexsort()
先按后面的参数进行排序
pandas 实现
用 pandas 实现相同的功能会更简单些:
df=DataFrame(a)
a_sort=df.sort([2,0],ascending=[1,0])
print (a_sort.values)
[[2 4 0]
[1 7 0]
[2 3 1]
[1 0 6]]