Eu criei um script Python que chama um script R e, em seguida, lê a saída novamente no Python. Eu posso executar esta ferramenta no ArcGIS Desktop (10.2.1) e funciona bem. Quando publico como serviço de geoprocessamento, ele falha quando atinge o script R. Eu verifiquei os caminhos dos arquivos e eles estão bem. É possível chamar scripts externos de um serviço de geoprocessamento? Aqui está o meu código.
import sys, os, arcpy
arcpy.AddMessage("Loaded Python Imports...")
try:
#User Input
lat = arcpy.GetParameterAsText(0)
long = arcpy.GetParameterAsText(1)
arcpy.AddMessage("LAT: " + "".join(lat))
arcpy.AddMessage("LONG: " + "".join(long))
#Create R Command
rScript = "test.R"
args = " ".join([lat, long])
RCMD = "R --slave --vanilla --args "
cmd = RCMD + args + " < " + rScript
#Execute
os.system(cmd)
#Render the Results
output = open("FILE PATH")
finalNumber = output.read()
print("The output is: " + " ".join(finalNumber))
arcpy.AddMessage("The output is: " + " ".join(finalNumber))
output.close()
#Delete Text File
os.remove("FILE PATH")
except Exception as e:
print e.message
arcpy.AddError(e.message)
python
arcgis-server
r
geoprocessing-service
Jeremy Hamm
fonte
fonte
Rscript test.R arg1 arg2 arg3
? Para o caso de você não estar ciente dessa opção, aqui está um exemplo simples de como isso se parece na prática.Respostas:
Eu encontrei este artigo: Integrando programas externos no ModelBuilder , é mais antigo e inicialmente parece estar fora do tópico, mas se você olhar para isso :, poderá ver que ele define explicitamente o caminho para o script R.
Quando seu script de geoprocessamento é executado no servidor, ele é executado em uma pasta de trabalho dentro do
jobs
diretório. Dependendo do processo de publicação, seu script R pode não estar lá. Sempre que me refiro a scripts externos nos meus serviços de geoprocessamento, sempre os refiro explicitamente a partir de uma pasta que foi registrada como uma fonte de dados .fonte
Você precisará usar a estrutura da ferramenta ESRI e incluir os arquivos na pasta de script se desejar referenciá-los diretamente pelo nome, como está fazendo no seu código. http://resources.esri.com/help/9.3/ArcGISDesktop/com/Gp_ToolRef/sharing_tools_and_toolboxes/a_structure_for_sharing_tools.htm
Caso contrário, você precisará anexar o local do script em seu sys.path. O exemplo abaixo faz referência ao arquivo "\ myFolder \ myModules \ myExtFile.py". Depois de ter uma referência válida ao seu arquivo, você pode usar suas funções personalizadas no serviço GP, desde que o local da publicação tenha acesso ao caminho da pasta.
fonte