Добавление поля в слой анализа (Network Analyst)

Уровень лицензии:BasicStandardAdvanced

Резюме

Позволяет добавлять поля в дочерние слои слоя сетевого анализа.

Использование

Синтаксис

AddFieldToAnalysisLayer_na (in_network_analysis_layer, sub_layer, field_name, field_type, {field_precision}, {field_scale}, {field_length}, {field_alias}, {field_is_nullable})
ПараметрОбъяснениеТип данных
in_network_analysis_layer

Слой сетевого анализа, к которому будет добавлено новое поле.

Network Analyst Layer
sub_layer

Дочерний слой слоя сетевого анализа, к которому будет добавлено новое поле.

String
field_name

Имя поля, добавляемого в указанный дочерний слой слоя сетевого анализа.

String
field_type

Тип поля, используемый при создании нового поля.

  • LONGЧисловые значения без дробных значений в пределах заданного интервала.
  • ТЕКСТИмена или другие текстовые значения.
  • FLOATЧисловые значения с дробными значениями в пределах заданного интервала.
  • DOUBLEЧисловые значения с дробными значениями в пределах заданного интервала.
  • SHORTЧисленные значения без дробных значений в пределах заданного интервала; кодированные значения.
  • DATEДата и/или время.
  • BLOBИзображения и другие виды мультимедиа.
String
field_precision
(дополнительно)

Определяет общее количество цифр, хранимых в поле. Учитываются все цифры, независимо от их расположения относительно разделяющей запятой.

Значение параметра действительно только для числовых типов полей.

Long
field_scale
(дополнительно)

Определяет количество знаков после запятой, хранимых в поле. Данный параметр применяется только для полей типа Float или Double.

Long
field_length
(дополнительно)

Длина добавляемого поля. Устанавливает максимально возможное количество знаков для каждой записи в поле. Эта опция применяется только к полям типа текстовый или Blob.

Long
field_alias
(дополнительно)

Альтернативное имя, добавляемое в качестве псевдонима к имени поля. Используется для расшифровки кратких и трудных для восприятия имен полей. Возможность добавлять псевдонимы доступна только для полей в классах и таблицах базы геоданных и покрытиях.

String
field_is_nullable
(дополнительно)

Географический объект, для которого нет связанной атрибутивной информации. Отличается от значения 0 или от отсутствия значения.

  • NON_NULLABLEНулевые значения для поля недопустимы.
  • NULLABLEДопустимы нулевые значения для поля. Это значение по умолчанию.
Boolean

Пример кода

AddFieldToAnalysisLayer, пример 1 (окно Python)

Следующий Скрипт в окне Python демонстрирует процедуру добавления поля UniqueID в дочерний слой Facilities слоя сетевого анализа Service Area.

import arcpy
arcpy.na.AddFieldToAnalysisLayer("Service Area","Facilities","UniqueID","LONG")
AddFieldToAnalysisLayer, пример 2 (рабочий процесс)

Следующий автономный скрипт Python демонстрирует процесс использования функции AddFieldToAnalysisLayer для переноса поля StationID из входных объектов пожарных частей в объекты полигона зон 2-, 3- и 5-минутной доступности, вычисленные службой анализа площадей. Поле StationID может использоваться для объединения атрибутов объектов пожарных частей с объектами полигонов зон обслуживания.

# 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)

Параметры среды

Связанные темы

Информация о лицензировании

ArcGIS for Desktop Basic: Да
ArcGIS for Desktop Standard: Да
ArcGIS for Desktop Advanced: Да
9/11/2013