QGIS批量将多部件要素合并

要在QGIS中批量将多部件要素合并,你可以使用PyQGIS编程来完成。
from qgis.core import QgsVectorLayer, QgsProject

# 设置待合并的多部件要素图层文件路径
input_file = '/path/to/input_layer.shp'
# 设置输出合并后的图层文件路径
output_file = '/path/to/output_layer.shp'

# 加载待合并的多部件要素图层
input_layer = QgsVectorLayer(input_file, 'Input Layer', 'ogr')

# 创建用于存储合并后要素的图层
output_layer = QgsVectorLayer('Polygon?crs=epsg:4326', 'Output Layer', 'memory')

# 复制输入图层的属性字段到输出图层中
output_layer_data_provider = output_layer.dataProvider()
output_layer_data_provider.addAttributes(input_layer.fields())
output_layer.updateFields()

# 遍历输入图层中的要素
for feature in input_layer.getFeatures():
    # 合并多部件要素
    merged_feature = feature.geometry().buffer(0)
    
    # 将合并后的要素添加到输出图层
    output_layer_data_provider.addFeatures([merged_feature])

# 保存输出图层
QgsProject.instance().addMapLayer(output_layer)
output_layer_data_provider.createSpatialIndex()
output_layer_data_provider.commitChanges()
QgsVectorLayerExporter.exportLayer(output_layer, output_file, 'utf-8', output_layer.crs(), 'ESRI Shapefile', onlySelected=False)

# 注意,上述代码需要确保已经安装并正确配置了QGIS Python环境,并导入了所需的库。请根据实际情况修改代码中的文件路径。

使用了QGIS中的`buffer()`函数来合并要素的多部件,然后将合并后的要素添加到输出图层中,并最终保存为一个新的矢量图层文件。请根据实际情况修改代码中的文件路径以适应你的实际情况,并确保已经安装所需的依赖库。

猜你喜欢

转载自blog.csdn.net/weixin_58851039/article/details/131320487