6 votos

Importación de herramientas de procesamiento de QGIS3 en un script independiente

Inspirado por esta pregunta Pero para QGIS 3 (y por lo tanto Python 3), me gustaría utilizar los algoritmos de procesamiento de QGIS en un script Python independiente sin GUI, con una instalación estándar de Ubuntu Linux.

Una simple import processing es insuficiente:

import processing
processing.run(
   "qgis:rasterlayerstatistics",
   {
       'INPUT': .'/somefile.tif',
       'BAND': 1,
       'OUTPUT_HTML_FILE': './result.html'
   }
)

Resultados en:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ModuleNotFoundError: No module named 'processing'

¿Cómo se accede a QGIS processing para utilizar los algoritmos de procesamiento de QGIS en un script independiente de Python (no en el intérprete de QGIS)?

5voto

alpha-beta-soup Puntos 1449

Este es un ejemplo de cómo acceder a processing para ejecutar el proceso de "estadísticas ráster" de QGIS, que devuelve información útil sobre una capa ráster. En particular, las estadísticas ráster son útiles para obtener la suma de todos los valores de un ráster, lo que (AFAIK) no puede hacerse sólo en GDAL.

#!/usr/bin/env python3
import os
import sys
import warnings
from functools import wraps

def ignore_warnings(f):
    @wraps(f)
    def inner(*args, **kwargs):
        with warnings.catch_warnings(record=True) as w:
            warnings.simplefilter("ignore")
            response = f(*args, **kwargs)
        return response
    return inner

def import_qgis_processing():
    sys.path.append('/usr/lib/qgis')
    sys.path.append('/usr/share/qgis/python/plugins')
    from qgis.core import QgsApplication, QgsProcessingFeedback, QgsRasterLayer
    app = QgsApplication([], False)
    feedback = QgsProcessingFeedback()
    return (app, feedback, QgsRasterLayer)

app, feedback, QgsRasterLayer = import_qgis_processing()
app.initQgis()

@ignore_warnings # Ignored because we want the output of this script to be a single value, and "import processing" is noisy
def initialise_processing(app):
    from qgis.analysis import QgsNativeAlgorithms
    import processing
    from processing.core.Processing import Processing
    Processing.initialize()
    app.processingRegistry().addProvider(QgsNativeAlgorithms())
    return (app, processing,)

def check_input_validity(QgsRasterLayer):
    raster = QgsRasterLayer(sys.argv[1], 'raster', 'gdal')
    if not raster.isValid():
        raise Exception('Invalid raster')

def raster_stats():
    params = {
        'INPUT': sys.argv[1],
        'BAND': 1
    }
    return processing.run(
        "qgis:rasterlayerstatistics",
        params, feedback=feedback
    )

def get_raster_stat(stat='SUM'):
    return raster_stats().get(stat)

app, processing = initialise_processing(app)
check_input_validity(QgsRasterLayer)
print(get_raster_stat(stat=sys.argv[2]))
app.exitQgis()

Le site ignore_warnings porque sin ella se emiten tres advertencias de obsoleto al importar processing y quería que el script tuviera una salida simple a stdout. Puede omitirlo si lo desea.

La importación de módulos dentro de funciones se realiza para controlar el orden de importación, y para detener linters (por ejemplo. autopep8 ) de intentar mover todas las sentencias import a la parte superior.

Los lugares clave que hay que incluir en sys.path son:

  • /usr/lib/qgis
  • /usr/share/qgis/python/plugins

Estos serían diferentes en diferentes sistemas operativos, y probablemente en diferentes distribuciones de Linux.

Este script se puede ejecutar como: ./rasterstats.py ./somefile.tif SUM y mostrará la suma de todos los valores de la trama en stdout (ignorando los valores sin datos si los hay). MAX , MIN etc. también funcionan.

Las funciones clave son import_qgis_processing y initialise_processing .

i-Ciencias.com

I-Ciencias es una comunidad de estudiantes y amantes de la ciencia en la que puedes resolver tus problemas y dudas.
Puedes consultar las preguntas de otros usuarios, hacer tus propias preguntas o resolver las de los demás.

Powered by:

X