Estou apenas começando a trabalhar nos scripts Python.
Atualmente, estou criando um script para automatizar um processo.
Basicamente, ele pergunta ao usuário o nome do cliente, obtém uma projeção, se disponível, cria um diretório na unidade C: para cliente, cria um banco de dados geográfico específico para o cliente, cria um conjunto de dados necessário e cria classes de recursos específicas para os dados do cliente. Eventualmente, ele também adicionará os campos obrigatórios a cada classe de recurso e provavelmente algumas outras coisas.
Comecei isso sem realmente conhecer a etiqueta adequada dos scripts Python para o ArcMap. Mas o que eu criei até agora só será executado fora do ArcMap, acredito.
Isso é aceitável?
Em vez de obter a entrada do usuário através do arcpy.getparamaterastext (), sobre o qual acabei de descobrir, estou usando raw_input ().
Tudo bem?
Funciona, mas não tenho certeza se essa é uma maneira adequada de criar scripts.
Aqui está o código que tenho até agora.
import sys
import arcpy
import os
#Records name of the client
client = raw_input("Enter the name of the client: (letters and underscores only) \n")
#Records filepath of client to be created
clientpath = "C:/" + client
#Inquires if projection file exists
projection = raw_input("Is there a .prj or .shp available with correct projection? Y or N \n")
#Records the projection location if available
if projection.upper() == "Y":
spatialr = raw_input("Drag the .prj or .shp here to record the filepath \n")
nspatialr = spatialr.replace('"', "")
elif projection.upper() == "N":
alert = raw_input("You must add the spatial reference manually, hit enter to continue. \n")
elif projection.upper() != "N" or "Y":
exit = raw_input("That is not a valid response. Try again. \n")
sys.exit()
#Checks if client folder exists; if not, creates one
if not os.path.exists(clientpath):
os.makedirs(clientpath)
#Variable for file geodatabase location
FGBpath = clientpath + "/" + client + ".gdb"
#Checks if client file geodatabase exists; if not, creates one
if not arcpy.Exists(FGBpath):
arcpy.CreateFileGDB_management(clientpath, client)
#Variable for dataset location
FDatasetpath = clientpath + "/" + client + ".gdb" + "/Network"
#Checks if dataset exists; if not, creates one
if not arcpy.Exists(FDatasetpath):
if projection.upper() == "Y":
arcpy.CreateFeatureDataset_management(FGBpath, "Network", nspatialr)
elif projection.upper() == "N":
arcpy.CreateFeatureDataset_management(FGBpath, "Network")
#Variable for cable feature class location
FCcablepath = clientpath + "/" + client + ".gdb" + "/Network" + "/cable"
#Checks if cable feature class exists; if not, creates one
if not arcpy.Exists(FCcablepath):
if projection.upper() == "Y":
arcpy.CreateFeatureclass_management (FDatasetpath, "cable", "POLYLINE", "", "", "", nspatialr)
elif projection.upper() == "N":
arcpy.CreateFeatureclass_management (FDatasetpath, "cable", "POLYLINE")
#Variable for splice point feature class location
FCsplicepath = clientpath + "/" + client + ".gdb" + "/Network" + "/splice_point"
#Checks if splice point feature class exists; if not, creates one
if not arcpy.Exists(FCsplicepath):
if projection == 'Y' or projection == 'y':
arcpy.CreateFeatureclass_management (FDatasetpath, "splice_point", "POINT", "", "", "", nspatialr)
elif projection == 'N' or projection == 'n':
arcpy.CreateFeatureclass_management (FDatasetpath, "splice_point", "POINT")
exit = raw_input("\n\n File geodatabase, dataset, and the cable \n and splice point feature classes successfully created. \n\n Hit enter to exit.")
Ainda tenho algum trabalho a fazer, como adicionar os campos necessários.
Além das ótimas sugestões de @ egdetti , você pode simplificar bastante seu script fazendo algumas suposições em vez de escrever a lógica if / else para cada pequena condição.
Por exemplo:
Em vez de verificar se cada item existe antes, apenas assuma que existe e substitua-o, definindo
arcpy.env.overwriteOutput = True
. Agora você pode ter algum motivo para verificar com antecedência, mas com mais freqüência do que não substituir é bom.Em vez de verificar se a opção de referência espacial foi configurada e chamar o mesmo comando de duas maneiras diferentes, basta passar a variável de referência espacial para o comando uma vez e deixá- lo manipular cadeias nulas ou vazias (o que será bom).
Use
os.path.join
para associar elementos do caminho do arquivo em vez de usar a concatenação de cadeias, que está repleta de perigos.Por exemplo, em vez de:
Usar:
fonte