如何切成numpy.ndarray由numpy.void数字组成



所以这是交易:我有变量x,即numpy.ndarray。该结构的大小为1000。如果我做x[0],那么我得到4个数字的numpy.void。如果我做x[1],那么我将获得另一个numpy.void,也有4个数字等。

我只想做的事情:我想切成此数据结构,以便提取一个尺寸为1000x3的numpy矩阵。

我该怎么做?谢谢

听起来您有一个结构化数组,类似于这个简单的示例:

In [158]: x = np.ones((5,), dtype='i,i,f,f')
In [159]: x
Out[159]: 
array([(1, 1,  1.,  1.), (1, 1,  1.,  1.), (1, 1,  1.,  1.),
       (1, 1,  1.,  1.), (1, 1,  1.,  1.)], 
      dtype=[('f0', '<i4'), ('f1', '<i4'), ('f2', '<f4'), ('f3', '<f4')])
In [160]: x[0]
Out[160]: (1, 1,  1.,  1.)
In [161]: type(x[0])
Out[161]: numpy.void

x[0]是记录,显示为元组。您按名称访问字段(不是"列"索引(:

In [162]: x['f0']
Out[162]: array([1, 1, 1, 1, 1], dtype=int32)
In [163]: x['f2'] = np.arange(5)
In [165]: x['f1'] = [10,12,8,0,3]
In [166]: x
Out[166]: 
array([(1, 10,  0.,  1.), (1, 12,  1.,  1.), (1,  8,  2.,  1.),
       (1,  0,  3.,  1.), (1,  3,  4.,  1.)], 
      dtype=[('f0', '<i4'), ('f1', '<i4'), ('f2', '<f4'), ('f3', '<f4')])
In [168]: x[['f2','f3']]    # 2 fields at once
Out[168]: 
array([( 0.,  1.), ( 1.,  1.), ( 2.,  1.), ( 3.,  1.), ( 4.,  1.)], 
      dtype=[('f2', '<f4'), ('f3', '<f4')])

当"列"中应包含不同的东西,例如一个字符串,另一个整数时,这很方便。但是将这种数组转换为相同数字类型的2D数组可能会很尴尬。

viewastype在有限的情况下工作,但是tolist是我知道的最强大的转换介质。

In [179]: x.tolist()
Out[179]: 
[(1, 10, 0.0, 1.0),
 (1, 12, 1.0, 1.0),
 (1, 8, 2.0, 1.0),
 (1, 0, 3.0, 1.0),
 (1, 3, 4.0, 1.0)]
In [180]: np.array(x.tolist())
Out[180]: 
array([[  1.,  10.,   0.,   1.],
       [  1.,  12.,   1.,   1.],
       [  1.,   8.,   2.,   1.],
       [  1.,   0.,   3.,   1.],
       [  1.,   3.,   4.,   1.]])

请注意,结构化数组的tolist是元组列表,而2D数组的tolist是列表。朝这个方向发展,差异无关紧要。差异差异很重要。

您是如何生成此数组的?来自带有genfromtxtcsv?作为其他一些数字软件包的输出?

最新更新