我有一个看起来像这样的数组,例如:
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]])
我还有另外两个数组,例如:
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]])
我想要的是从第二个数组到相应位置的第一个数组中选择值 2891,从第三个数组到相应位置的第一个数组中选择 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
引用第二个数组。它的作用只是将所有 0 值替换为 2891 值。有人可以帮忙吗?