Numpy基于XYZ获取最大值

2024-09-28 22:44:10 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图读取一个带有XYZ数据的CSV文件,但是当使用pythonnatgrid进行网格划分时,出现了一个错误:two input triples have the same x/y coordinates。这是我的阵列:

np.array([[41.540588, -100.348335, 0.052785],
   [41.540588, -100.348335, 0.053798],
   [42.540588, -102.348335, 0.021798],
   [42.540588, -102.348335, 0.022798],
   [43.540588, -103.348335, 0.031798]])

我想删除XY重复项并得到最大Z值。根据上面的示例,我想删除此数组的所有最小值:

^{pr2}$

我尝试过使用np.unique,但到目前为止我没有任何运气,因为它不能处理行(只有列)。在


Tags: 文件csvthe数据网格inputhave错误
3条回答

如果您能够使用pandas,那么可以利用groupby和{}

>>> pandas.DataFrame(arr).groupby([0,1], as_index=False).max().values

array([[ 4.15405880e+01, -1.00348335e+02,  5.37980000e-02],
       [ 4.25405880e+01, -1.02348335e+02,  2.27980000e-02],
       [ 4.35405880e+01, -1.03348335e+02,  3.17980000e-02]])

这是一种numpy的方法,首先按Z排序,然后找到每个唯一的X和{}对中的第一个,然后索引:

a = np.array([[41.540588, -100.348335, 0.052785],
   [41.540588, -100.348335, 0.053798],
   [42.540588, -102.348335, 0.021798],
   [42.540588, -102.348335, 0.022798],
   [43.540588, -103.348335, 0.031798]])

# sort by Z
b = a[np.argsort(a[:,2])[::-1]]
# get first index for each unique x,y pair
u = np.unique(b[:,:2],return_index=True,axis=0)[1]
# index
c = b[u]
>>> c
array([[ 4.15405880e+01, -1.00348335e+02,  5.37980000e-02],
       [ 4.25405880e+01, -1.02348335e+02,  2.27980000e-02],
       [ 4.35405880e+01, -1.03348335e+02,  3.17980000e-02]])

您可以通过排序和删除重复项来使用Pandas:

import pandas as pd

df = pd.DataFrame(arr)

res = df.sort_values(2, ascending=False)\
        .drop_duplicates([0, 1])\
        .sort_values(0).values

print(res)

array([[  4.15405880e+01,  -1.00348335e+02,   5.37980000e-02],
       [  4.25405880e+01,  -1.02348335e+02,   2.27980000e-02],
       [  4.35405880e+01,  -1.03348335e+02,   3.17980000e-02]])

相关问题 更多 >