Я создаю плагин 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
Никаких исключений не возникает, но выходные данные не создаются и не добавляются в оглавление, но в журнале создается следующий журнал 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
.
Я получаю ту же проблему при запуске через графический интерфейс QGIS и использовании раскрывающегося меню, чтобы выбрать scratch
слой, который находится в оглавлении. Это происходит независимо от того, указывается ли выходной растр в оперативной памяти или указывается место на диске.
Этот вопрос кажется похожим, но их решение состояло в том, чтобы добавить слой памяти в оглавление перед его использованием. Я уже делаю это, и все же ошибка сохраняется.
Я думал, что это общая проблема со слоями памяти и алгоритмами геообработки QGIS, но без проблем работает следующее:
processing.runandload("qgis:fixeddistancebuffer",self.vlayer, 500, 5, True, "output_buffer.shp")
Что я делаю неправильно? Почему мой набор данных источника памяти «не может быть указан» в некоторых алгоритмах обработки?
EDIT: вот исходный код из , gdalogr:gridinvdist
если это полезно.