5

たとえば、次のような配列があります。

array([[ 1,  1,  2,  0,  4],
       [ 5,  6,  7,  8,  9],
       [10,  0,  0, 13, 14],
       [15, 16, 17, 18, 19],
       [20, 21, 22,  0, 24],
       [25, 26, 27, 28, 29],
       [30, 31, 32, 33, 34],
       [35, 36, 37, 38, 39],
       [40, 41, 42, 43, 44],
       [45, 46, 47, 48, 49]])

次のような別の2つの配列があります。

array([[   0,    0,    0,    0],
       [   0,    0,    0,    0],
       [   0, 2891,    0,    0],
       [   0,    0,    0,    0],
       [   0,    0,    0, 2891]])

array([[  0,   0,   0, 643],
       [  0,   0,   0,   0],
       [  0,   0, 643,   0],
       [  0,   0,   0,   0],
       [  0,   0,   0,   0]])

私が望むのは、2番目の配列から対応する位置の最初の配列に値2891を選択し、3番目の配列から対応する位置の最初の配列に643を選択して、最終的な配列が次のようになるようにすることです。

array([[   1,    1,    2,  643,    4],
       [   5,    6,    7,    8,    9],
       [  10, 2891,  643,   13,   14],
       [  15,   16,   17,   18,   19],
       [  20,   21,   22, 2891,   24],
       [  25,   26,   27,   28,   29],
       [  30,   31,   32,   33,   34],
       [  35,   36,   37,   38,   39],
       [  40,   41,   42,   43,   44],
       [  45,   46,   47,   48,   49]])

これまでのところ、このコマンドを試しました:

np.place(a,a<1, np.amax(b))

ここでa、最初の配列をb参照し、2 番目の配列を参照します。それが何をするかは、すべての 0 値を 2891 値に置き換えるだけです。誰か助けてくれませんか?

4

3 に答える 3

5

非ゼロ メソッドを使用して、yとが非ゼロのインデックスを見つけることができます。z

In [9]: y.nonzero()
Out[9]: (array([2, 4]), array([1, 3]))

In [10]: z.nonzero()
Out[10]: (array([0, 2]), array([3, 2]))

関連する値は、インデックスを作成することで選択できます。

In [11]: y[y.nonzero()]
Out[11]: array([2891, 2891])

xでこれらの値を場所に割り当てることができます

In [13]: x[y.nonzero()] = y[y.nonzero()]

import numpy as np
x = np.array([[ 1,  1,  2,  0,  4],
              [ 5,  6,  7,  8,  9],
              [10,  0,  0, 13, 14],
              [15, 16, 17, 18, 19],
              [20, 21, 22,  0, 24],
              [25, 26, 27, 28, 29],
              [30, 31, 32, 33, 34],
              [35, 36, 37, 38, 39],
              [40, 41, 42, 43, 44],
              [45, 46, 47, 48, 49]])

y = np.array([[   0,    0,    0,    0],
              [   0,    0,    0,    0],
              [   0, 2891,    0,    0],
              [   0,    0,    0,    0],
              [   0,    0,    0, 2891]])

z = np.array([[  0,   0,   0, 643],
              [  0,   0,   0,   0],
              [  0,   0, 643,   0],
              [  0,   0,   0,   0],
              [  0,   0,   0,   0]])

x[y.nonzero()] = y[y.nonzero()]
x[z.nonzero()] = z[z.nonzero()]
print(x)

収量

[[   1    1    2  643    4]
 [   5    6    7    8    9]
 [  10 2891  643   13   14]
 [  15   16   17   18   19]
 [  20   21   22 2891   24]
 [  25   26   27   28   29]
 [  30   31   32   33   34]
 [  35   36   37   38   39]
 [  40   41   42   43   44]
 [  45   46   47   48   49]]
于 2013-05-13T11:49:38.513 に答える
0

numpy では、奇妙な方法で配列に添字を付けることができます。1. ブール配列を使用 2. インデックスを使用

a1[a2 > 0] = a2[a2.nonzero()]
于 2013-05-13T11:56:22.883 に答える