Чи можливо використовувати шари пам'яті в алгоритмах обробки QGIS?


12

Я будую плагін QGIS, який підключається до бази даних MySQL в локальній мережі, а потім додає підмножину однієї з таблиць до рівня пам'яті; підмножина базується на валюті даних (бере лише останнє спостереження для кожного місця, де проводяться вимірювання). Цей шар пам'яті успішно створений.

Однак я хочу запустити деякі алгоритми геообробки, і у мене виникають проблеми з використанням шару пам'яті в будь-якому з них.

    self.stationuri = "point?crs=epsg:4326&field=id:integer&field={}:double&index=yes".format(self.cb_field.currentText())
    self.vlayer = QgsVectorLayer(self.stationuri,"scratch","memory")
    if not self.vlayer.isValid():
        raise Exception("Failed to create in-memory layer")
    self.vlayer.startEditing()
    for i,r in enumerate(result): # Result is row-by-row result of SQL query
        # Add features
        ...
    self.vlayer.commitChanges()
    self.vlayer.updateExtents()
    # Add layer to map
    QgsMapLayerRegistry.instance().addMapLayer(self.vlayer)
    # Layer is successfully added to map with all features and geometry
    # BELOW IS WHERE IT FALLS APART
    try:
        processing.runandload("gdalogr:gridinvdist",self.vlayer,self.cb_field.currentText(),2,0,0,0,0,0,0,0,'Float32',None) # None = in-memory output; I get the same error if I specify a string path and filename.
    except Exception, e:
        raise e

Виняток не піднімається, але вихід TOC не виробляється і не додається, але складається такий журнал processing.log:

INFO|Mon May 04 2015 11:28:23|GDAL execution console output|/bin/sh: 1: /tmp/processing/bbebe7599c83446d9c2b03a251879657/OUTPUT.tif: not found|/bin/sh: 1: -zfield: not found||FAILURE: Source datasource is not specified.|Usage: gdal_grid [--help-general] [--formats]|    [-ot {Byte/Int16/UInt16/UInt32/Int32/Float32/Float64/|          CInt16/CInt32/CFloat32/CFloat64}]|    [-of format] [-co "NAME=VALUE"]|    [-zfield field_name] [-z_increase increase_value] [-z_multiply multiply_value]|    [-a_srs srs_def] [-spat xmin ymin xmax ymax]|    [-clipsrc <xmin ymin xmax ymax>|WKT|datasource|spat_extent]|    [-clipsrcsql sql_statement] [-clipsrclayer layer]|    [-clipsrcwhere expression]|    [-l layername]* [-where expression] [-sql select_statement]|    [-txe xmin xmax] [-tye ymin ymax] [-outsize xsize ysize]|    [-a algorithm[:parameter1=value1]*]    [-q]|    <src_datasource> <dst_filename>||Available algorithms and parameters with their's defaults:|    Inverse distance to a power (default)|        invdist:power=2.0:smoothing=0.0:radius1=0.0:radius2=0.0:angle=0.0:max_points=0:min_points=0:nodata=0.0|    Moving average|        average:radius1=0.0:radius2=0.0:angle=0.0:min_points=0:nodata=0.0|    Nearest neighbor|        nearest:radius1=0.0:radius2=0.0:angle=0.0:nodata=0.0|    Various data metrics|        <metric name>:radius1=0.0:radius2=0.0:angle=0.0:min_points=0:nodata=0.0|        possible metrics are:|            minimum|            maximum|            range|            count|            average_distance|            average_distance_pts|

Важлива частина , як видається, FAILURE: Source datasource is not specified.однак self.vlayer.isValid() == True, так що я не розумію , що сталося з моїм входом. Я спробував підставляючи self.vlayerз 'memory:scratch'у виклику processing.runandload, але потім я отримую наступне повідомлення про помилку виводиться на консоль (але не підняв) Error: Wrong parameter value: memory:scratch.

У мене виникає така ж проблема, коли я запускаю це через GUI QGIS і використовуючи спадне меню, щоб вибрати мій scratchшар, що знаходиться в TOC. Це відбувається, якщо я вказати растровий вихід як пам'ять або вказати місце на диску.

Це питання здається подібним, але їх рішенням було додати шар пам'яті до TOC перед його використанням. Я вже роблю це, і все ж помилка зберігається.

Я подумав, що це загальна проблема із шарами пам'яті та алгоритмами геообробки QGIS, але такі проблеми працюють без проблем:

processing.runandload("qgis:fixeddistancebuffer",self.vlayer, 500, 5, True, "output_buffer.shp")

Що я роблю неправильно? Чому в деяких алгоритмах обробки не можна "вказати" мій набір даних джерела пам'яті?

EDIT: ось вихідний код з , gdalogr:gridinvdistякщо це корисно.

Відповіді:


4

Схоже, шари пам'яті не можна використовувати як вхід для сценаріїв обробки GDAL / OGR, оскільки обробка не може належним чином підготувати дані для використання з ogr2ogr. Ось чому, наприклад, буферний інструмент QGIS працює, але інструмент буфера GDAL / OGR виходить з ладу:

Algorithm Buffer vectors starting...
GDAL command:
cmd.exe /C ogr2ogr.exe "C:\Users\anita\AppData\Local\Temp\processing70e5e0852cb9456ba2e3780f8386122e\86d237c8f41443f58a230a8133172047\OUTPUTLAYER.shp" point?crs=EPSG:4326&memoryid={6772bccd-f55d-461d-aff6-6271ded02eea} point?crs=EPSG:4326&memoryid={6772bccd-f55d-461d-aff6-6271ded02eea} -dialect sqlite -sql "SELECT ST_Buffer( geometry , 1000 ),* FROM 'point?crs=EPSG:4326&memoryid={6772bccd-f55d-461d-aff6-6271ded02eea}' " 
GDAL command output:
FAILURE: 
Unable to open datasource `point?crs=EPSG:4326' with the following drivers. 
-> JP2ECW 
-> OCI 
-> SOSI 
...

Обробка повинна якось підготувати дані (зберегти їх у файл), а потім подати їх у інструмент GDAL / OGR.

Я відкрив квиток: Неможливо використовувати шари пам'яті з інструментами OGR


2

Це правильний спосіб, як пояснено в документації http://docs.qgis.org/2.14/es/docs/user_manual/processing/console.html

наступний код працює з пам'яттю всі, крім останнього, що це завантаження

MDT=path/mdt.tif
drain=processing.runalg("grass:r.drain",MDT,"",(pun),False,False,False,"%f,%f,%f,%f"% (xmin, xmax, ymin, ymax),0,-1,0.00100,None)
vect=processing.runalg("grass:r.to.vect",drain['output'],0,False,"%f,%f,%f,%f"% (xmin, xmax, ymin, ymax),0,None)
bu=processing.runalg("qgis:fixeddistancebuffer",vect['output'],Metros_afecta,1,False,None)
buf=bu['OUTPUT']
bufe= QgsVectorLayer(buf,"area", "ogr")
#the last load the layer 
QgsMapLayerRegistry.instance().addMapLayers([bufe])

process.runalg повертає словник у цьому випадку bu ['OUTPUT'] OUTPUT IS KEY, а значення - тимчасовий шлях, за допомогою якого ви можете бачити ключ із processseing.alghelp ("обробка імені") як обробка, alghelp ("трава" : r.drain ")

повернення

processing.alghelp("grass:r.drain")
ALGORITHM: r.drain - Traces a flow through an elevation model on a raster map.
input <ParameterRaster>
coordinate <ParameterString>
vector_points <ParameterMultipleInput>
-c <ParameterBoolean>
-a <ParameterBoolean>
-n <ParameterBoolean>
GRASS_REGION_PARAMETER <ParameterExtent>
GRASS_REGION_CELLSIZE_PARAMETER <ParameterNumber>
GRASS_SNAP_TOLERANCE_PARAMETER <ParameterNumber>
GRASS_MIN_AREA_PARAMETER <ParameterNumber>
output <OutputRaster>

у цьому випадку ключ виводиться , будьте обережні, з великої літери ви повинні писати з великої літери або з капіталом, у цьому випадку не з капіталу


Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.