Feld zu Analyse-Layer hinzufügen (Network Analyst)
Zusammenfassung
Fügt einem Sublayer eines Netzwerkanalyse-Layers ein Feld hinzu.
Verwendung
-
Das Werkzeug wird meistens zusammen mit dem Werkzeug Standorte hinzufügen verwendet, um Felder von den Eingabe-Features auf die Sublayer zu übertragen. Wenn Sie beispielsweise ein Feld mit dem Namen "UniqueID" von den Eingabe-Features in den Sublayer "Facilities" (Einrichtungen) des Layers "Service Area" (Einzugsgebiet) übertragen möchten, verwenden Sie zuerst dieses Werkzeug, um dem Sublayer "Facilities" das Feld "UniqueID" hinzuzufügen; anschließend verwenden Sie die Feldzuordnungen im Werkzeug Standorte hinzufügen, um Eingabewerte für das Feld "UniqueID" bereitzustellen.
-
Allen Sublayern der Netzwerkanalyse-Layer können Felder hinzugefügt werden.
Syntax
Parameter | Erläuterung | Datentyp |
in_network_analysis_layer |
Der Netzwerkanalyse-Layer, dem das neue Feld hinzugefügt wird. | Network Analyst Layer |
sub_layer |
Der Sublayer des Netzwerkanalyse-Layers, dem das neue Feld hinzugefügt wird. | String |
field_name |
Der Name des Felds, das dem ausgewählten Sublayer des Netzwerkanalyse-Layers hinzugefügt wird. | String |
field_type |
Der für die Erstellung des neuen Feldes verwendete Feldtyp.
| String |
field_precision (optional) |
Bestimmt die Anzahl der Ziffern, die im Feld gespeichert werden können. Dabei werden alle Ziffern berücksichtigt, unabhängig davon, auf welcher Seite des Dezimalkommas sie sich befinden. Der Parameterwert ist nur für Zahlenfeldtypen gültig. | Long |
field_scale (optional) |
Legt die Anzahl der Dezimalstellen fest, die in einem Feld gespeichert werden können. Dieser Parameter wird nur für die Felddatentypen "Float" und "Double" verwendet. | Long |
field_length (optional) |
Die Länge des hinzugefügten Feldes. Dadurch wird die maximal zulässige Anzahl von Zeichen für jeden Datensatz des Feldes festgelegt. Diese Option ist nur in Feldern des Typs "Text" oder "Blob" anwendbar. | Long |
field_alias (optional) |
Der alternative Name für den Feldnamen. Dieser dient als aussagekräftigere Beschreibung für kryptische Feldnamen. Der Parameter "Feldalias" gilt nur für Geodatabases und Coverages. | String |
field_is_nullable (optional) |
Ein geographisches Feature, das keine zugehörigen Attributinformationen besitzt. Der Parameter unterscheidet sich von Nullfeldern oder leeren Feldern. Er wird nur für Felder in einer Geodatabase unterstützt.
| Boolean |
Codebeispiel
Im folgenden Skript im Python-Fenster wird veranschaulicht, wie dem Einrichtungen-Sublayer des Netzwerkanalyse-Layers "Einzugsgebiet" ein Feld "UniqueID" hinzugefügt wird.
import arcpy
arcpy.na.AddFieldToAnalysisLayer("Service Area","Facilities","UniqueID","LONG")
Das folgende eigenständige Python-Skript veranschaulicht, wie Sie mit der AddFieldToAnalysisLayer-Funktion das Feld "StationID" aus den Eingabe-Features für Feuerwachen in die Polygon-Features für das Einzugsgebiet von 2, 3 und 5 Minuten übertragen, die bei der Einzugsgebiet-Analyse berechnet wurden. Das Feld "StationID" kann verwendet werden, um andere Attribute in den Feuerwachen-Features mit den Einzugsgebiet-Polygon-Features zu verbinden.
# Name: AddFieldToAnalysisLayer_Workflow.py
# Description: Transfers the Address field from the input fire station
# features to the 2-,3-, and 5-minute service area polygon features
# calculated from a service area analysis. The Address field can
# be used to join other attributes from the fire station features
# to the service area polygon features.
# Requirements: Network Analyst Extension
#Import system modules
import arcpy
from arcpy import env
try:
#Check out the Network Analyst extension license
arcpy.CheckOutExtension("Network")
#Set environment settings
env.workspace = "C:/data/SanFrancisco.gdb"
env.overwriteOutput = True
#Set local variables
inNetworkDataset = "Transportation/Streets_ND"
outNALayerName = "FireStationsCoverage"
impedanceAttribute = "TravelTime"
defaultBreakValues = "2 3 5"
fieldName = "Address"
fieldType = "TEXT"
inFeatures = "Analysis/FireStations"
searchTolerance = "2 Miles"
outFeatures = outNALayerName + "Area"
saFacilities = "Facilities"
saPolygons = "SAPolygons"
#Create a new service area analysis layer. For this scenario, the default
#value for all the remaining parameters statisfies the analysis requirements
outNALayer = arcpy.na.MakeServiceAreaLayer(inNetworkDataset, outNALayerName,
impedanceAttribute,"",
defaultBreakValues)
#Get the layer object from the result object. The service layer can now be
#referenced using the layer object.
outNALayer = outNALayer.getOutput(0)
#Get the names of all the sublayers within the service area layer.
subLayerNames = arcpy.na.GetNAClassNames(outNALayer)
#Stores the layer names that we will use later
facilitiesLayerName = subLayerNames[saFacilities]
polygonLayerName = subLayerNames[saPolygons]
#Get the layer objects for all the sublayers within the service area layer
#The first layer returned by ListLayers is the Service area layer itself
#which we don't want to use.
subLayers = {}
for layer in arcpy.mapping.ListLayers(outNALayer)[1:]:
subLayers[layer.datasetName] = layer
#Store the layer objects that we will use later
facilitiesLayer = subLayers[saFacilities]
polygonLayer = subLayers[saPolygons]
#Add a Address field to the Facilities sublayer of the service area layer.
#This is done before loading the fire stations as facilities so that the
#Address values can be transferred from the input features to the
#Facilities sublayer. The service area layer created previously is
#referred by the layer object.
arcpy.na.AddFieldToAnalysisLayer(outNALayer,facilitiesLayerName,fieldName,
fieldType)
#Add the fire station features as Facilities and map the Name and the
#Address properties from the Name and Address fields from fire station
#features using the field mappings.
fieldMappings = arcpy.na.NAClassFieldMappings(outNALayer, facilitiesLayerName)
fieldMappings['Name'].mappedFieldName = "Name"
fieldMappings['Address'].mappedFieldName = "Address"
arcpy.na.AddLocations(outNALayer,facilitiesLayerName,inFeatures,
fieldMappings, searchTolerance)
#Solve the service area layer
arcpy.na.Solve(outNALayer)
#Transfer the Address field from Facilities sublayer to Polygons sublayer
#of the service area layer since we wish to export the polygons. The
#FacilityID field in Polygons sub layer is related to the ObjectID field in
#the Facilities sub layer.
arcpy.management.JoinField(polygonLayer, "FacilityID",facilitiesLayer,
"ObjectID", fieldName)
#Export the Polygons sublayer to a feature class on disk.
arcpy.management.CopyFeatures(polygonLayer, outFeatures)
print "Script completed successfully"
except Exception as e:
# If an error occurred, print line number and error message
import traceback, sys
tb = sys.exc_info()[2]
print "An error occured on line %i" % tb.tb_lineno
print str(e)