Я работаю над сценарием Python в QGIS и пытаюсь растеризовать векторный слой, содержащий один многоугольник.Я использую QGIS 3.2 и обнаруживаю следующую трассировку, с которой я не могу справиться:
File "C:\OSGEO4~1\apps\Python36\lib\code.py", line 91, in runcode
exec(code, self.locals)
File "<input>", line 1, in <module>
File "<string>", line 118, in <module>
File "C:\OSGEO4~1\apps\Python36\lib\site-packages\osgeo\gdal.py", line 2738, in RasterizeLayer
return _gdal.RasterizeLayer(*args, **kwargs)
TypeError: in method 'RasterizeLayer', argument 4 of type 'OGRLayerShadow *'
Следующий код генерирует ошибку выше (строка 118 - последняя строка):
# 5. rasterize vector layer and save as tiff
gdal.UseExceptions()
# a) define resolution and NoData value of new raster
x_res = 0.001 # degree per pixel
y_res = 0.001 # smaller value gives larger tiffs (higher resolution)
NoData_value = -9999
# b) filename for output
_out = r"D:/asdf23.tiff"
# c) get extent of layer
qgsRect = layer.extent()
x_min = qgsRect.xMinimum(); x_max = qgsRect.xMaximum()
y_min = qgsRect.yMinimum(); y_max = qgsRect.yMaximum()
# d) create target - TIFF
nbPixelX = int( (x_max - x_min) / x_res )
nbPixelY = int( (y_max - y_min) / y_res )
srs = layer.sourceCrs()
raster = gdal.GetDriverByName('GTiff').Create(_out, nbPixelX, nbPixelY, 1, gdal.GDT_Int32)
raster.SetProjection(srs.toWkt())
raster.SetGeoTransform((x_min, x_res, 0, y_max, 0, -y_res))
band = raster.GetRasterBand(1)
band.SetNoDataValue(NoData_value)
# e) Rasterize
err = gdal.RasterizeLayer(raster, [1], layer, burn_values=[102])
Любые советы и подсказки очень ценятся, так как у меня заканчиваются идеи.Спасибо!