Instrução
No ArcGIS Pro, o ArcGIS API for Python pode ser utilizado para automatizar o processo de atualização dos registros de dados de campo na tabela de atributos de uma classe de feição a partir de um arquivo CSV. Siga o fluxo de trabalho descrito neste artigo para atualizar a tabela de atributos de um arquivo CSV e adicionar novas linhas usando um arquivo Python independente (.py). O arquivo Python também é executado no Jupyter Notebook.
import arcpy
fc = r"<featureClassPath>" csv = r"<csvPath>" copy_fields = ["<fieldName1>", "<fieldName2>", "<fieldName3>"]
csv_dict = {row[0]: row for row in arcpy.da.SearchCursor(csv, copy_fields)}
with arcpy.da.UpdateCursor(fc, copy_fields) as cursor:
for row in cursor:
key = row[0]
try:
new_row = csv_dict[key]
except KeyError:
print(f"Entry not found in csv: {copy_fields[0]} = {key}")
continue
cursor.updateRow(new_row)
del csv_dict[key]
with arcpy.da.InsertCursor(fc, copy_fields) as cursor: for new_row in csv_dict.values(): cursor.insertRow(new_row)
print("<message>")
O bloco de código abaixo demonstra o funcionamento completo do script.
fc = r"C:\Users\testUser\Documents\Article work\Article 29321\MyProject 29321\MyProject 29321.gdb\Schools_all"
csv = r"C:\Users\testUser\Documents\Article work\Article 29321\schoolLvl.csv"
copy_fields = ["NAME", "LEVEL_NO", "LEVEL"]
import arcpy
csv_dict = {row[0]: row for row in arcpy.da.SearchCursor(csv, copy_fields)}
with arcpy.da.UpdateCursor(fc, copy_fields) as cursor:
for row in cursor:
key = row[0]
try:
new_row = csv_dict[key]
except KeyError:
print(f"Entry not found in csv: {copy_fields[0]} = {key}")
continue
cursor.updateRow(new_row)
del csv_dict[key]
with arcpy.da.InsertCursor(fc, copy_fields) as cursor:
for new_row in csv_dict.values():
cursor.insertRow(new_row)
print("Complete")
ID do Artigo: 000029321
Obtenha ajuda de especialistas do ArcGIS
Comece a conversar agora