Co muszę zrobić:
- zmień nazwę nazwy tabeli / klasy obiektów
- skopiuj wszystkie wartości do nowego pola
Do tej pory zrobiłem następujący kod, jak sugeruje @ artwork21:
import sys
import traceback
import arcpy
from arcpy import env
## ARGUMENTS
# argv[1] = input table/feature class path
# argv[2] = input old field name
# argv[3] = input new field name
path = sys.argv[1]
oldFieldName = sys.argv[2]
newFieldName = sys.argv[3]
env.overwriteOutput = True
fields = arcpy.ListFields(path)
for field in fields:
if field.aliasName == oldFieldName:
if not oldFieldName == newFieldName:
fieldType = field.type
# Add new field
arcpy.AddField_management(path, newFieldName, fieldType)
#Calculates the new field based on old field values
arcpy.CalculateField_management(path, newFieldName, "!"+oldFieldName+"!", "PYTHON", "")
# Delete the old field (if necessary)
arcpy.DeleteField_management(path, oldFieldName)
Jak mogę odwzorować field.type
na AddField_management
typ pola metody? A gdy pole znajduje się na środkowym miejscu, wówczas pole jest usuwane ze środka i dodawane do ostatniego. Nie wygląda to tak, jakby nazwa pola została zmieniona.
Czy jest jakieś lepsze rozwiązanie, które pomaga mi robić te rzeczy?
old_field
nazwa zmiennej lub rzeczywista nazwa starego pola? Jeśli jest to nazwa zmiennej, musisz użyć formatowania łańcucha lub konkatenacji, aby zawrzeć wartość zmiennej w nawiasach (parser VB) lub wykrzyknikach (parser Python).