时间:2021-05-22
本文实例讲述了Python实现二维数组按照某行或列排序的方法。分享给大家供大家参考,具体如下:
lexsort支持对数组按指定行或列的顺序排序;是间接排序,lexsort不修改原数组,返回索引。
(对应lexsort 一维数组的是argsort a.argsort()这么使用就可以;argsort也不修改原数组, 返回索引)
默认按最后一行元素有小到大排序, 返回最后一行元素排序后索引所在位置。
设数组a, 返回的索引ind,ind返回的是一维数组
对于一维数组, a[ind]就是排序后的数组。
对于二维数组下面会详细举例。
import numpy as np>>> aarray([[ 2, 7, 4, 2], [35, 9, 1, 5], [22, 12, 3, 2]])按最后一列顺序排序
>>> a[np.lexsort(a.T)]array([[22, 12, 3, 2], [ 2, 7, 4, 2], [35, 9, 1, 5]])按最后一列逆序排序
>>>a[np.lexsort(-a.T)]array([[35, 9, 1, 5], [ 2, 7, 4, 2], [22, 12, 3, 2]])按第一列顺序排序
>>> a[np.lexsort(a[:,::-1].T)]array([[ 2, 7, 4, 2], [22, 12, 3, 2], [35, 9, 1, 5]])按最后一行顺序排序
>>> a.T[np.lexsort(a)].Tarray([[ 2, 4, 7, 2], [ 5, 1, 9, 35], [ 2, 3, 12, 22]])按第一行顺序排序
>>> a.T[np.lexsort(a[::-1,:])].Tarray([[ 2, 2, 4, 7], [ 5, 35, 1, 9], [ 2, 22, 3, 12]])更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数组操作技巧总结》、《Python字符串操作技巧汇总》、《Python函数使用技巧总结》、《Python入门与进阶经典教程》及《Python数据结构与算法教程》
希望本文所述对大家Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python实现二维有序数组查找的方法。分享给大家供大家参考,具体如下:题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从
如何根据二维数组中的某一行或者某一列排序?假设data是一个numpy.array类型的二维数组,可以利用numpy中的argsort函数进行实现,代码实例如下
(1)B=sort(A)对一维或二维数组进行升序排序,并返回排序后的数组,当A为二维时,对数组每一列进行排序.eg:A=[1,5,3],则sort(A)=[1,
本文实例讲述了C#实现的二维数组排序算法。分享给大家供大家参考,具体如下:classOrder{//////对二维数组排序//////排序的二维数组///排序根
题目描述:在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维