python - numpy 按两个字段(升序和降序)对结构化数组进行排序

标签 python arrays sorting numpy

我有这行代码:

TableArr = numpy.sort(TableArr, order=['destID','ATTRACT'])

我需要 'ATTRACT' 命令降序,而 destID 升序,这是两者的默认设置。尝试使用 [::-1] 失败,因为它反转了整个数组。

我将添加一个可以设置为 TrueFalsereverse 参数 elsewhere , 但它对我不起作用并且在 Numpy 的 documentation 中没有提到.

最佳答案

这是一个测试我评论中想法的交互式 session :

In [1]: import numpy as np

In [2]: dt = np.dtype([('destID',int),('ATTRACT',float),('other','S10')])
In [3]: TableArr=np.zeros((10,),dt)
In [5]: TableArr['destID']=np.random.randint(10,size=(10,))
In [6]: TableArr['ATTRACT']=np.random.randint(100,size=(10,))

In [7]: TableArr
Out[7]: 
array([(2, 39.0, b''), (7, 7.0, b''), (8, 74.0, b''), (5, 83.0, b''),
       (5, 3.0, b''), (9, 26.0, b''), (8, 9.0, b''), (3, 1.0, b''),
       (1, 67.0, b''), (7, 5.0, b'')], 
      dtype=[('destID', '<i4'), ('ATTRACT', '<f8'), ('other', 'S10')])

In [13]: Tcopy=TableArr[['destID','ATTRACT']].copy()
# use copy() to avoid a FutureWarning

In [14]: Tcopy['ATTRACT'] *= -1  # 'reverse' a field

In [16]: I=np.argsort(Tcopy,order=['destID','ATTRACT'])

In [17]: I
Out[17]: array([8, 0, 7, 3, 4, 1, 9, 2, 6, 5], dtype=int32)

In [18]: TableArr[I]
Out[18]: 
array([(1, 67.0, b''), (2, 39.0, b''), (3, 1.0, b''), (5, 83.0, b''),
       (5, 3.0, b''), (7, 7.0, b''), (7, 5.0, b''), (8, 74.0, b''),
       (8, 9.0, b''), (9, 26.0, b'')], 
      dtype=[('destID', '<i4'), ('ATTRACT', '<f8'), ('other', 'S10')])

整数在增加,而对于它们并列的 3 种情况, float 在减少。所以它有效。

关于python - numpy 按两个字段(升序和降序)对结构化数组进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32393339/

相关文章:

python - pandas DataFrame - 查找偏移列之间的最大值

python - 从 Python 发出系统调用,获取输出文件名

javascript - jqplot : how to display value from an array in a highlighter

arrays - 在 O(n) 时间和 O(1) 额外空间内找到最大重复数

python - 在 Azure Notebook VM 中找不到名为 'azure.datalake' 或 pip 的模块

python - Celery + RabbitMQ 结果后端 + WebSockets?

c++ - 关于将指向数组的指针作为函数参数的困惑

java - 如何从 int 数组中随机选择,然后删除所选元素

sorting - 如何按顺序打印LUA表?

ruby - ruby 中的排序列表