python 二维数组 坐标 np.agrsort 优先级排序 原理

python 二维数组 坐标 np.agrsort 优先级排序 原理,第1张

对一串坐标就行排序
坐标(x,y),首先按照y从小到大排序,然后以7个为一组,组内按照x小到大排序。

zb=np.array(zb)#将坐标数组类型转换

zb=zb[zb[:,1].argsort()]#对所有行依据第一列进行排序
#1.zb[:,1]是第一列的值序列
#2.zb[:,1].argsort()返回的是排序后的索引,即下标
#将zb以7行为以小组,组内按照x排序
i=0
while i<lenth:
    zb[i:i + 7, :] = zb[zb[i:i + 7, 0].argsort() + i]
    i+=7
#zb[i:i + 7, 0].argsort()返回的索引是针对i到i+7行内的,其取值范围为0-6,对于zb整个数组来说其索引值为zb[i:i + 7, 0].argsort()+i。
#zb[i:i + 7, :] = zb[zb[i:i + 7, 0].argsort() + i]将排序后的结果存储到原来位置


#运行结果
***
zb排序前
 [[1601, 1300, 1807, 1765], [1364, 1300, 1585, 1771], [1124, 1279, 1351, 1750], [886, 1271, 1127, 1748], [657, 1263, 877, 1733], [188, 1257, 415, 1729], [410, 1255, 639, 1728], [1308, 749, 1526, 1218], [1560, 746, 1770, 1214]]
zb依据第2列排序结果
 [[1560  746 1770 1214]
 [1308  749 1526 1218]
 [ 410 1255  639 1728]
 [ 188 1257  415 1729]
 [ 657 1263  877 1733]
 [ 886 1271 1127 1748]
 [1124 1279 1351 1750]
 [1601 1300 1807 1765]
 [1364 1300 1585 1771]]
zb7个为一组按照第一列排序结果
 [[ 188 1257  415 1729]
 [ 410 1255  639 1728]
 [ 657 1263  877 1733]
 [ 886 1271 1127 1748]
 [1124 1279 1351 1750]
 [1308  749 1526 1218]
 [1560  746 1770 1214]
 [1364 1300 1585 1771]
 [1601 1300 1807 1765]]
 ***
  

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/796208.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-06
下一篇2022-05-06

发表评论

登录后才能评论

评论列表(0条)

    保存