Lat,Lon,值CSV到使用Python的光栅地图

2024-09-27 04:23:21 发布

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

如果我有一个带有Lat、Lon和Value字段的CSV数据集,那么使用python生成光栅地图的最佳方法是什么?“光栅Z”字段可以是该表中的任何列。。在

L5  L6  L7  L8  L9  L10 L11 L12 L13 L14 LAT LON
3.571732    1.338448    0   9.96921E+36 -3.482845   -1.42944    133.229919  141.246002  67.685631   5.059844    24.335797   -95.088764
3.571732    1.338448    0   9.96921E+36 -3.420345   -1.42944    132.749512  140.641464  67.318848   5.105563    24.335107   -95.060013
3.571732    1.338448    0   9.96921E+36 -3.420345   -1.42944    132.230164  140.047211  67.318848   5.063346    24.334408   -95.031263
3.571732    1.338448    0   9.96921E+36 -3.420345   -1.42944    132.230164  139.463104  67.318848   5.063346    24.333701   -95.002512
3.509232    1.369698    0   9.96921E+36 -3.357845   -1.42944    131.702133  137.82196   66.940475   5.021552    24.332986   -94.973763
3.509232    1.369698    0   9.96921E+36 -3.357845   -1.49194    131.702133  137.26651   66.043732   5.021552    24.332263   -94.945013
3.509232    1.369698    0   9.96921E+36 -3.357845   -1.49194    131.165268  136.72081   66.043732   4.980192    24.331531   -94.916265
3.509232    1.338448    0   9.96921E+36 -3.357845   -1.49194    131.165268  136.184738  66.043732   4.980192    24.330792   -94.887516

请记住,这些是numpy数组


Tags: csv数据方法value光栅地图lonlat
1条回答
网友
1楼 · 发布于 2024-09-27 04:23:21

有两个选项取决于你的经纬度坐标。当Lat,Lon坐标形成等距网格时,可以使用第一个选项,否则可以使用下面的第二个选项。在


第一种选择

我在下面创建了一个数组,第一列是值,第二列和第三列是Lat,Lon:

import numpy as np

lat = np.arange(0, 15, 5)
lon = np.arange(0, 10, 5)
val = np.random.randint(0,10, size =len(lat)*len(lon))
xx, yy = np.meshgrid(lon, lat)
array = np.array([val,  yy.ravel(), xx.ravel()]).T
print(array)

>>> array([[ 7,  0,  0],
           [ 8,  0,  5],
           [ 7,  5,  0],
           [ 3,  5,  5],
           [ 2, 10,  0],
           [ 8, 10,  5]])

当你的Lat,Lon坐标被整齐地排序后,你可以改变值的形状来得到一个网格数组,如下所示:

^{pr2}$

第二种选择

当你有一堆随机的Lat,Lon坐标值如下所示:

array = np.random.randint(0,10, size =(6,3))
print(array)
>>> array([[9 6 0]
           [7 8 8]
           [6 0 9]
           [7 7 4]
           [2 4 3]
           [0 2 9]])

可以使用如下插值将其转换为栅格:

from scipy import interpolate

lon_list = np.arange(3, 6, 1)
lat_list = np.arange(4, 8, 1)

lon_2d, lat_2d = np.meshgrid(lon_list, lat_list)
grid_array = interpolate.griddata((array[:,-1], array[:,-2]), array[:,0],
                                  (lon_2d, lat_2d))[::-1]
print(grid_array)

>>> [[  nan  7.    6.72]
     [ 6.    5.4   5.6 ]
     [ 4.    3.8   4.  ]
     [ 2.    2.2   2.4 ]]

请注意,如果网格单元不在点的边界内,则会获得nan值。在

您可以使用plt.imshow公司在

import matplotlib.pyplot as plt
plt.imshow(grid_array)

相关问题 更多 >

    热门问题