mirror of
https://github.com/qgis/QGIS.git
synced 2025-04-15 00:04:00 -04:00
[BUGFIX][Processing] RScript: Insert None value as NULL
This commit is contained in:
parent
2a746f493f
commit
021da12c9f
@ -373,37 +373,46 @@ class RAlgorithm(GeoAlgorithm):
|
||||
|
||||
for param in self.parameters:
|
||||
if isinstance(param, ParameterRaster):
|
||||
value = param.value
|
||||
value = value.replace('\\', '/')
|
||||
if self.passFileNames:
|
||||
commands.append(param.name + ' = "' + value + '"')
|
||||
elif self.useRasterPackage:
|
||||
commands.append(param.name + ' = ' + 'brick("' + value
|
||||
+ '")')
|
||||
if param.value is None:
|
||||
commands.append(param.name + '= NULL')
|
||||
else:
|
||||
commands.append(param.name + ' = ' + 'readGDAL("' + value
|
||||
+ '")')
|
||||
value = param.value
|
||||
value = value.replace('\\', '/')
|
||||
if self.passFileNames:
|
||||
commands.append(param.name + ' = "' + value + '"')
|
||||
elif self.useRasterPackage:
|
||||
commands.append(param.name + ' = ' + 'brick("' + value
|
||||
+ '")')
|
||||
else:
|
||||
commands.append(param.name + ' = ' + 'readGDAL("' + value
|
||||
+ '")')
|
||||
elif isinstance(param, ParameterVector):
|
||||
value = param.getSafeExportedLayer()
|
||||
value = value.replace('\\', '/')
|
||||
filename = os.path.basename(value)
|
||||
filename = filename[:-4]
|
||||
folder = os.path.dirname(value)
|
||||
if self.passFileNames:
|
||||
commands.append(param.name + ' = "' + value + '"')
|
||||
if param.value is None:
|
||||
commands.append(param.name + '= NULL')
|
||||
else:
|
||||
commands.append(param.name + ' = readOGR("' + folder
|
||||
+ '",layer="' + filename + '")')
|
||||
value = param.getSafeExportedLayer()
|
||||
value = value.replace('\\', '/')
|
||||
filename = os.path.basename(value)
|
||||
filename = filename[:-4]
|
||||
folder = os.path.dirname(value)
|
||||
if self.passFileNames:
|
||||
commands.append(param.name + ' = "' + value + '"')
|
||||
else:
|
||||
commands.append(param.name + ' = readOGR("' + folder
|
||||
+ '",layer="' + filename + '")')
|
||||
elif isinstance(param, ParameterTable):
|
||||
value = param.value
|
||||
if not value.lower().endswith('csv'):
|
||||
raise GeoAlgorithmExecutionException(
|
||||
'Unsupported input file format.\n' + value)
|
||||
if self.passFileNames:
|
||||
commands.append(param.name + ' = "' + value + '"')
|
||||
if param.value is None:
|
||||
commands.append(param.name + '= NULL')
|
||||
else:
|
||||
commands.append(param.name + ' <- read.csv("' + value
|
||||
+ '", head=TRUE, sep=",")')
|
||||
value = param.value
|
||||
if not value.lower().endswith('csv'):
|
||||
raise GeoAlgorithmExecutionException(
|
||||
'Unsupported input file format.\n' + value)
|
||||
if self.passFileNames:
|
||||
commands.append(param.name + ' = "' + value + '"')
|
||||
else:
|
||||
commands.append(param.name + ' <- read.csv("' + value
|
||||
+ '", head=TRUE, sep=",")')
|
||||
elif isinstance(param, ParameterExtent):
|
||||
if param.value:
|
||||
tokens = unicode(param.value).split(',')
|
||||
@ -413,12 +422,21 @@ class RAlgorithm(GeoAlgorithm):
|
||||
else:
|
||||
commands.append(param.name + ' = NULL')
|
||||
elif isinstance(param, ParameterCrs):
|
||||
commands.append(param.name + ' = "' + param.value + '"')
|
||||
if param.value is None:
|
||||
commands.append(param.name + '= NULL')
|
||||
else:
|
||||
commands.append(param.name + ' = "' + param.value + '"')
|
||||
elif isinstance(param, (ParameterTableField, ParameterTableMultipleField, ParameterString,
|
||||
ParameterFile)):
|
||||
commands.append(param.name + '="' + param.value + '"')
|
||||
if param.value is None:
|
||||
commands.append(param.name + '= NULL')
|
||||
else:
|
||||
commands.append(param.name + '="' + param.value + '"')
|
||||
elif isinstance(param, (ParameterNumber, ParameterSelection)):
|
||||
commands.append(param.name + '=' + unicode(param.value))
|
||||
if param.value is None:
|
||||
commands.append(param.name + '= NULL')
|
||||
else:
|
||||
commands.append(param.name + '=' + unicode(param.value))
|
||||
elif isinstance(param, ParameterBoolean):
|
||||
if param.value:
|
||||
commands.append(param.name + '=TRUE')
|
||||
|
Loading…
x
Reference in New Issue
Block a user