Python从较大的2D NumPy数组创建一个较小的子数组?

时间:2013-06-28 16:52:49

标签: python arrays numpy indexing

所以我有一个大的NumPy数组,它采用以下形式:

data = [[2456447.64798471, 4, 15.717, 0.007, 5, 17.308, 0.019, 6, 13.965, 0.006],
        [2456447.6482855, 4, 15.768, 0.018, 5, 17.347, 0.024, 6, 14.001, 0.023],
        [2456447.648575, 4, 15.824, 0.02, 5, 17.383, 0.024, 6, 14.055, 0.023]]

我想创建一个如下所示的子数组:

[[4, 15.717, 5, 17.308, 6, 13.965], 
 [4, 15.768, 5, 17.347, 6, 14.001],
 [4, 15.824, 5, 17.383, 6, 14.055]]

基本上我想要选出第一列,然后从第4列开始,我想选择每第3列。我试图弄清楚如何使用像data[1:6:?]这样的方法来解决这个问题,但我不明白如何逐步完成并只得到我想要的列。

另外,我需要这个可以扩展为水平扩展的数组。所以我不只是想对列值进行硬编码。

2 个答案:

答案 0 :(得分:7)

你可以这样做:

>>> data[:, [1, 2, 4, 5, 7, 8]]
array([[  4.   ,  15.717,   5.   ,  17.308,   6.   ,  13.965],
       [  4.   ,  15.768,   5.   ,  17.347,   6.   ,  14.001],
       [  4.   ,  15.824,   5.   ,  17.383,   6.   ,  14.055]])

答案 1 :(得分:3)

这样就可以了,它可以水平和垂直地缩放,而且很容易操作。

subArray = []
newRow = []
for row in data:
    for i in xrange(0,len(row)):
        if (i % 3 == 0):
            continue
        newRow.append(row[i])
    subArray.append(newRow)
    newRow = []