伊迩 2025-06-01 12:31 采纳率: 66.7%
浏览 4
已结题

不同分辨率栅格数据打标签

我有两份栅格数据,经纬度范围裁剪到大概一致,坐标系和投影方式一致。投影方式: EPSG:4326 地理坐标系: EPSG:4326
但空间分辨率不同: A:空间分辨率是0.1° B数据:空间分辨率是2km,并且A数据的纬度顺序是从小到大,B数据的纬度顺序是从大到小。
并且我已经A数据上已经划分出了降水区域,
请问如何将A数据上的降水位置在B上映射出正确的位置,来进行打标签

  • 写回答

5条回答 默认 最新

  • 阿里嘎多学长 2025-06-01 12:31
    关注

    阿里嘎多学长整理AIGC生成,因移动端显示问题导致当前答案未能完全显示,请使用PC端查看更加详细的解答过程

    解决方案

    你遇到的问题是不同分辨率栅格数据打标签的问题。由于坐标系和投影方式一致,可以使用 Python 语言中的 geopandas 库来实现数据的合并和标签。

    首先,需要安装 geopandas 库:

    pip install geopandas
    

    然后,可以使用以下代码来实现数据的合并和标签:

    import geopandas as gpd
    
    # 读取数据A
    gdf_A = gpd.read_file('A.shp', crs='EPSG:4326')
    
    # 读取数据B
    gdf_B = gpd.read_file('B.shp', crs='EPSG:4326')
    
    # 将数据A和数据B合并
    gdf_merged = gpd.sjoin(gdf_A, gdf_B, how='inner', op='intersects')
    
    # 将合并后的数据写入到新的shapefile中
    gdf_merged.to_file('merged.shp', driver='ESRI Shapefile')
    

    在上面的代码中,我们首先读取数据A和数据B,然后使用 gpd.sjoin 函数将数据A和数据B合并,最后将合并后的数据写入到新的shapefile中。

    需要注意的是,在合并数据时,需要指定合并的方式为 how='inner',以便只保留交集部分的数据。同时,需要指定合并的操作为 op='intersects',以便将数据A和数据B根据空间位置进行合并。

    希望这个解决方案能够帮助你解决问题!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 6月9日
  • 已采纳回答 6月1日
  • 创建了问题 6月1日