希望一切顺利。 我有一个非常大的 numpy 数组,想将其分成几个。我的数组有三列,我想在所有列都达到最大值的地方将其拆分:
array = [[0, 0, 0],
[0, 0, 5],
[10, 5, 10],
[1, 1, 1],
[5, 5, 15],
[10, 8, 20],
[2, 0, 0],
[10, 10, 12],
[1, 2, 0],
[2, 5, 9]]
现在,我想将其分成四个数组:
sub_array_1=[[0, 0, 0],
[0, 0, 5],
[10, 5, 10]]
sub_array_2=[[1, 1, 1],
[5, 5, 15],
[10, 8, 20]]
sub_array_3=[[2, 0, 0],
[10, 10, 12]]
sub_array_4=[[1, 2, 0],
[2, 5, 9]]
我尝试在一个 for 循环中使用 if 语句,表示当输入的每个元素都大于存储在上行和下行中的元素时,给我一个数组。我还应该弄清楚最后一行:
import numpy as np
sub_array_1=np.array([])
for i in array:
if array[i,:]>array[i+1,:] and array[i,:]>array[i+1,:]:
vert_1=np.append(sub_array_1,array[0:i,:])
我的代码不起作用,但它只是显示了我的想法。 我对 Python 很陌生,我找不到将我的想法编写为代码的方法。因此,我感谢任何帮助和贡献。 干杯, 阿里
最佳答案
IIUC,将 numpy.diff
与 numpy.array_split
结合使用的一种方法:
indices = np.argwhere(np.all(np.diff(array, axis=0) < 0, axis=1))
np.array_split(array, indices.ravel()+1, axis=0)
输出:
[array([[ 0, 0, 0],
[ 0, 0, 5],
[10, 5, 10]]),
array([[ 1, 1, 1],
[ 5, 5, 15],
[10, 8, 20]]),
array([[ 2, 0, 0],
[10, 10, 12]]),
array([[1, 2, 0],
[2, 5, 9]])]
np.all
和np.diff
查找一行,该行的所有元素与下一行(即峰值结束的位置)均为负差<np.array_split
然后将根据找到的峰值位置分割给定的数组。
关于python - 在满足峰值的地方分割数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63941274/