- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个结构化的 numpy 数组,我正在按顺序对其进行排序。
它工作得很好,但只有一个方向!
降序:
sort(myStructuredArray,order=my_order)[::-1]
sort(myStructuredArray,order=my_order)
[col1,col2,-col3,col4,-col5,...,colN]
对于某些列,我想按 col1,col2 和 colN 升序排序,而对于其他列,则按 col3 和 col5 (减号信号) 降序排序。
最佳答案
你可以用 numpy.lexsort
来做到这一点
In [1]: import numpy as np
In [2]: a = np.array([(4,0), (1,9), (1,0), (4,9)],
dtype=[('x',int),('y',float)])
In [3]: a
Out[3]:
array([(4, 0.0), (1, 9.0), (1, 0.0), (4, 9.0)],
dtype=[('x', '<i8'), ('y', '<f8')])
In [4]: a['x']
Out[4]: array([4, 1, 1, 4])
In [5]: a['y']
Out[5]: array([ 0., 9., 0., 9.])
lexsort
参数的顺序优先级与
np.sort(..., order=...)
相反.因此,首先按降序排序
'x'
然后通过升序
'y'
:
In [6]: a[np.lexsort((a['y'], -a['x']))]
Out[6]:
array([(4, 0.0), (4, 9.0), (1, 0.0), (1, 9.0)],
dtype=[('x', '<i8'), ('y', '<f8')])
a['x'][::-1]
作为 key 而不是 -a['x']
但这对我现在不起作用。 关于Python Numpy recarray 排序双向,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15972568/
假设我用相同的 dtype 制作了两个 recarrays 并将它们堆叠起来: >>> import numpy as np >>> dt = [('foo', int), ('bar', float
如果我以这种方式创建一个 recarray: In [29]: np.rec.fromrecords([(1,'hello'),(2,'world')],names=['a','b']) 结果看起来不
我有一对 numpy 数组;这是一个简单的等效示例: t = np.linspace(0,1,100) data = ((t % 0.1) * 50).astype(np.uint16) 我希望这些是
我有一个结构化的 numpy 数组,我正在按顺序对其进行排序。 它工作得很好,但只有一个方向! 降序: sort(myStructuredArray,order=my_order)[::-1] 和 上
我有一个名为 data.csv 的数据文件 name,value A,10 1,20 B,30 3,20 ... 所以问题是我使用 numpy 和 mlab 来加载这个 csvfile data =
在numpy docs的一次访问多个字段部分中, 说: 请注意,字段总是以相同的顺序返回,不管它们被要求的顺序如何。 文档还给出了一个例子如下: >>> x = np.array([(1.5,2.5,
我有一个 csv 文件,其中两列(v3 和 v7)对于所有观察结果都是空白的: v1,v2,v3,v4,v5,v6,v7 GNB,1980,,20,-1.168689,0.4619077, GNB,1
给定一个元组列表,其中每个元组代表表中的一行,例如 tab = [('a',1),('b',2)] 有没有一种简单的方法可以将其转换为记录数组?我试过了 np.recarray(tab,dtype=[
构造结构化/重载数组时,我对类型转换的行为感到困惑: 这个简单的示例接受数字字段,但将类型定义为字符串: data = [(1.0, 2), (3.0, 4)] np.array(data, dtyp
有没有一种简单的方法可以在不创建新的 recarray 的情况下将记录/行添加到 numpy recarray?假设我有一个占用 1Gb 内存的 recarray,我希望能够向其中添加一行而不让 py
我用 C# 编写了一个数据使用者,它从 python API 脚本读取字符串数据。到目前为止,我发现性能最好的方法是将数据放入 python 中的 numpy-recarray,将其打印到控制台并使用
我正在尝试复制一个recarray 并更改新数组中字段/记录的名称。但是,这会修改原始数组的名称(但是,这些值并未取消链接)。例子: import numpy as np import copy 定义
我在创建 datetime64 类型的记录数组时遇到问题。我正在运行 Python 2.7、Numpy 1.7。 这是一个最小的例子: p_dtype = np.dtype({"names": ['t
numpy.recarray.tobytes 的逆是什么? >>> import numpy as np >>> A = np.array([(28483,27759)],dtype=[('x','>
我想创建一个 numpy.recarray 的子类,当数据添加到超出其当前长度的行时自动调整大小。 下面的代码完成了大部分我想要的。 class autorecarray(numpy.recarray
我在 QGIS-user forum 上发布了这个问题但这可能太技术性了,因此我也捕获机会在这里尝试一下。 我的计划是有一个 QGIS 插件来读取和绘制与矢量图层中选定点对应的时间序列数据(这些点代表
有没有一种方便的方法可以删除 recarray 中包含某些值的行?假设我有以下数组, a=numpy.array([(1.0, 2.0, 3.0), (4.0, 5.0, 10.0),(1.0,10.
我有一个来自读取 csv 文件的 recarray。我有兴趣将列的子集转换为连续的 float 组。我想避免将它们转换为列表或将它们一一堆叠。我尝试了 https://stackoverflow.co
我是 numpy 的新手,我正在尝试替换 recarray 中的值。所以我有这个数组: import numpy as np d = [('1', ''),('4', '5'),('7', '8')]
我有一个 recarray,其中包含几个用于选择子集的列。有点像 >>> x array([ ('label1',True,3), ('label2',True,2),
我是一名优秀的程序员,十分优秀!