[英]Saving out a generated vector layer QGIS 3.6 python script
我正在尝试在 QGIS 3.6 中的线条形状文件上运行一些工具,以消除几何错误并识别自相交。 我让脚本工作,以便它输出 2 个图层:“Cleaned_Lines”:删除了重复和无效几何图形的线条图层,以及“Intersections”:一个点形状文件,它指示线条与它们自身相交的区域。 这些图层被创建并作为临时图层加载到 QGIS 中。 我希望“Cleaned_Lines”层自动保存到与输入线层相同的目录中。
# Check validity
alg_params = {
'IGNORE_RING_SELF_INTERSECTION': False,
'INPUT_LAYER': parameters['lines'],
'METHOD': 2,
'VALID_OUTPUT': QgsProcessing.TEMPORARY_OUTPUT
}
in_path = self.parameterDefinition('lines').valueAsPythonString(parameters['lines'], context)
directory = os.path.dirname(in_path)
output_path = os.path.join(os.path.dirname(in_path), "CleanedLines.shp'")
...
# Delete duplicate geometries
alg_params = {
'INPUT': outputs['CheckValidity']['VALID_OUTPUT'],
'OUTPUT': parameters['CleanedLines']
}
cleaned = processing.run('qgis:deleteduplicategeometries', alg_params, context=context, feedback=feedback, is_child_algorithm=True)
outputs['DeleteDuplicateGeometries'] = processing.run('qgis:deleteduplicategeometries', alg_params, context=context, feedback=feedback, is_child_algorithm=True)
results['CleanedLines'] = outputs['DeleteDuplicateGeometries']['OUTPUT']
cleaned_lines_layer = results['CleanedLines']
print(cleaned_lines_layer)
layer = QgsVectorLayer(cleaned_lines_layer, 'CleanedLines', 'ogr')
if not os.path.isfile(output_path) or Overwrite_Results_Files:
writer = QgsVectorFileWriter.writeAsVectorFormat(layer, output_path, 'CP1250', layer.crs(), 'ESRI Shapefile')
cleaned_lines_layer = output_path
layer = None
我排除了将文件写入变量“output_path”指示的目录,但它只是将其创建为临时层,脚本完成。 任何见解将不胜感激!
from qgis.core import QgsVectorFileWriter
QgsVectorFileWriter.writeAsVectorFormat(layer, "output_path", "UTF-8", layer.crs(), "ESRI Shapefile")
我在没有作家的情况下使用它并且它有效
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.