news 2026/2/3 2:19:53

GDAL 实现矢量合并

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GDAL 实现矢量合并

前言

矢量数据作为数据处理的半壁江山,在日常工作中涉及到多种操作,矢量数据合并也是一项常用操作,该功能涉及到两个及以上的数据源在几何对象与属性对象之间的合并操作。

在之前的文章中讲了如何使用GDAL或者ogr2ogr工具将txt以及csv文本数据转换为Shp格式,本篇教程在之前一系列文章的基础上讲解如何使用GDAL 实现矢量合并

  • GDAL 简介
  • GDAL 下载安装
  • GDAL 开发起步
  • GDAL 实现 GIS 数据读取转换(全)

如果你还没有看过,建议从以上内容开始。

1. 开发环境

本文使用如下开发环境,以供参考。

时间:2025年

系统:Windows 11

Python:3.11.7

GDAL:3.11.1

2.Union合并方法

矢量图层Layer对象上具有一个方法Union可用于数据裁剪。该方法接收合并图层和结果图层两个必填参数,剩下三个可选参数,最后返回一个整型值。

"""
说明:GDAL 矢量合并
参数:
-unionLayer:用于裁剪的矢量图层
-resultLayer:生成结果数据图层
"
""
def Union(unionLayer,resultLayer):

3. 矢量图层合并

老规矩定义一个图层合并方法LayerUnion用于数据合并,该方法接收如下三个参数。

"""
说明:GDAL 图层合并操作
参数:
-sourcePath: 源文件Shp数据路径
-unionPath:用于合并的Shp数据路径
-resultPath:用于存放合并结果的数据路径
"
""
def LayerUnion(sourcePath,unionPath,resultPath):

然后添加数据驱动,只不过在添加数据驱动前使用checkFilePath方法检查文件路径是否存在,之后判断数据驱动是否正常。

# 检查文件是否存在
checkFilePath(sourcePath)
checkFilePath(unionPath)
checkFilePath(resultPath)

# 添加数据驱动
shpDriver = ogr.GetDriverByName("ESRI Shapefile")

# 检查数据驱动是否正常
checkDriver(shpDriver)

在打开Shp数据源时传递第二个可选参数,该参数为布尔类型,将其值设置为True意为以可写模式打开数据源。

"""
以可写模式打开数据源
"
""

# 获取数据源
# sourceDs = shpDriver.Open(sourcePath)
# unionDs = shpDriver.Open(unionPath)
sourceDs = shpDriver.Open(sourcePath,True)
clipDs = shpDriver.Open(unionPath,True)

以源数据图层sourceLayer属性结构创建结果图层,获取源图层空间参考以及几何数据类型信息,并创建结果图层属性字段。

# 获取图层
sourceLayer = sourceDs.GetLayer(0)
srs = sourceLayer.GetSpatialRef()
geomType = sourceLayer.GetGeomType()

unionLayer = unionDs.GetLayer(0)

# 创建输出数据源
resultDs = shpDriver.CreateDataSource(resultPath)

# 根据源数据结构创建输出图层
resultLayer = resultDs.CreateLayer("resultLayer",srs,geomType)

# 添加数据结构
featureDefn = sourceLayer.GetLayerDefn()
fieldCount = featureDefn.GetFieldCount()

# 创建要素
# resultFeature = ogr.Feature(featureDefn)

# 添加字段(复制源图层字段定义)
foriinrange(fieldCount):
fieldDefn = featureDefn.GetFieldDefn(i)
resultLayer.CreateField(fieldDefn)

在源数据图层上调用方法Union进行图层合并,返回值为一个整型数值。合并完成后关闭所有数据源并返回结果。

print(f"~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~图层合并开始~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~")
"""
图层裁剪
"
""
result = sourceLayer.Union(unionLayer,resultLayer,[],GetProgress,GetData)
print(f"裁剪结果:{result}")

# 关闭数据源
sourceDs = unionDs = resultDs = None
print(f"~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~图层合并结束~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~")
returnresult

GetProgress为获取裁剪进度函数。

"""
说明:定义进度获取函数
参数:
-complete:完成度(0.0-1.0)
-message:进度消息
-userData:用户数据
"
""
def GetProgress(complete,message,userData):
print(f"进度:{complete * 100:.1f}% - {message}")
# 返回1表示继续处理,返回0表示取消
return1

GetData为获取裁剪数据函数。


def GetData(data):
print("裁剪数据:")

数据合并信息输出如下。

裁剪数据在ArcGIS中显示如下。

4. 注意事项

windows开发环境中同时安装GDALPostGIS,其中投影库PROJ的环境变量指向PostGIS的安装路径,在运行GDAL程序时,涉及到要素、几何与投影操作时会导致异常。具体意思为GDAL不支持PostGIS插件中的投影库版本,需要更换投影库或者升级版本。

RuntimeError: PROJ: proj_identify: D:Program FilesPostgreSQL13sharecontribpostgis-3.5projproj.db contains DATABASE.LAYOUT.VERSION.MINOR = 2 whereas a number >= 5 is expected. It comes from another PROJ installation.

解决办法为修改PROJ的环境变量到GDAL支持的版本或者在GDAL程序开头添加以下代码:

os.environ['PROJ_LIB'] = r'D:\Programs\Python\Python311\Libsite-packages\osgeo\data\proj'
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/1 18:36:57

Vivado2021.1安装教程:集成SDK的完整环境搭建

Vivado 2021.1 安装实战:从零搭建带 SDK 的 FPGA 开发环境 你是不是正准备开始 FPGA 项目,却被一堆安装文档搞得头大?尤其是看到“Vivado SDK”这种组合时,总担心漏掉哪一步会导致后面软件打不开、工程编译失败? 别…

作者头像 李华
网站建设 2026/2/1 19:50:37

入门必看:Windows平台下C#上位机开发起步

从零开始:用C#打造你的第一款工业级上位机你有没有过这样的经历?手里的单片机已经能采集温度、读取传感器数据,但想实时监控却只能靠串口助手“看数字”?调试时满屏乱跳的十六进制让人头大,客户更是一脸茫然&#xff1…

作者头像 李华
网站建设 2026/2/2 23:52:20

模拟电路设计验证:电路仿真的关键应用

模拟电路设计的“数字沙盘”:为什么仿真决定成败你有没有经历过这样的场景?花了几周时间画好原理图、打样PCB、焊好元件,结果一通电——输出电压不对,运放自激振荡,或者噪声大得像收音机调台。更糟的是,问题…

作者头像 李华
网站建设 2026/1/29 20:56:22

数字电路实验中的逻辑门优化策略深度剖析

数字电路实验中的逻辑门优化:从卡诺图到FPGA的实战精要在数字电路实验室里,你是否曾面对一堆74系列芯片和错综复杂的跳线感到头大?明明功能实现了,但电路板上密密麻麻的连线让人怀疑自己是不是在“绣花”;更糟的是&…

作者头像 李华
网站建设 2026/1/30 7:37:11

Terraform字符串操作:巧妙处理Azure容器注册表域名

在使用Terraform进行基础设施即代码(Infrastructure as Code)时,字符串操作是常见的需求。本文将通过一个具体的实例,介绍如何利用Terraform的字符串函数来修改Azure容器注册表(Azure Container Registry, ACR&#xf…

作者头像 李华
网站建设 2026/2/1 19:51:52

动态更新Mat表格的技巧与实例

在使用Angular Material的Mat表格时,经常会遇到需要在添加新数据后动态更新表格的问题。尤其是当我们使用对话框(Dialog)模块来添加新数据时,表格的更新变得尤为复杂。本文将通过实例讲解如何在对话框添加新数据后,成功更新Mat表格。 背景介绍 假设我们有一个产品管理系…

作者头像 李华