Я пытаюсь запустить некоторые инструменты на шейп-файле линий в 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", но он просто создает его как временный слой, и сценарий завершается. Любое понимание будет оценено!