ArcGIS Desktop

  • ArcGIS Pro
  • ArcMap

  • My Profile
  • Aide
  • Sign Out
ArcGIS Desktop

ArcGIS Online

La plateforme cartographique de votre organisation

ArcGIS Desktop

Un SIG professionnel complet

ArcGIS Enterprise

SIG dans votre entreprise

ArcGIS Developers

Outils de création d'applications de localisation

ArcGIS Solutions

Modèles d'applications et de cartes gratuits pour votre secteur d'activité

ArcGIS Marketplace

Téléchargez des applications et des données pour votre organisation.

  • Documentation
  • Support
Esri
  • Se connecter
user
  • Mon profil
  • Déconnexion

ArcMap

  • Accueil
  • Commencer
  • Carte
  • Analyser
  • Gérer les données
  • Outils
  • Extensions

Ajouter un champ à la couche d'analyse

  • Résumé
  • Utilisation
  • Syntaxe
  • Exemple de code
  • Environnements
  • Informations de licence

Résumé

Ajoute un champ à la sous-couche d'une couche d’analyse de réseau.

Utilisation

  • Cet outil s'utilise principalement avec l'outil Ajouter des localisations pour transférer des champs des entités en entrée aux sous-couches. Par exemple, si vous souhaitez transférer un champ appelé UniqueID de vos entités en entrée vers la sous-couche Facilities de la couche Service Area, utilisez cet outil pour ajouter le champ UniqueID à la sous-couche Facilities, puis utilisez les appariements de champs dans l’outil Ajouter des emplacements pour fournir des valeurs en entrée pour le champ UniqueID.

  • Il est possible d'ajouter des champs à l'une des sous-couches des couches d'analyse de réseau.

Syntaxe

arcpy.na.AddFieldToAnalysisLayer(in_network_analysis_layer, sub_layer, field_name, field_type, {field_precision}, {field_scale}, {field_length}, {field_alias}, {field_is_nullable})
ParamètreExplicationType de données
in_network_analysis_layer

Couche d'analyse de réseau à laquelle le nouveau champ sera ajouté.

Network Analyst Layer
sub_layer

Sous-couche de la couche d'analyse de réseau auquel le nouveau champ sera ajouté.

String
field_name

Nom du champ ajouté à la sous-couche spécifiée de la couche d'analyse de réseau.

String
field_type

Type de champ utilisé pour la création du nouveau champ.

  • LONG — Nombres entiers compris entre -2 147 483 648 et 2 147 483 647.
  • TEXT —Toute chaîne de caractères.
  • FLOAT — Nombres fractionnels compris entre -3,4E38 et 1,2E38.
  • DOUBLE — Nombres fractionnels compris entre-2,2E308 et 1,8E308.
  • SHORT — Nombres entiers compris entre -32 768 et 32 767.
  • DATE —Date et/ou heure.
  • BLOB —Longue séquence de nombres binaires. Vous avez besoin d'une visionneuse ou d'un chargeur personnalisé, ou d'une application tierce pour charger des attributs dans un champ BLOB ou afficher le contenu d'un champ BLOB.
String
field_precision
(Facultatif)

Nombre de chiffres pouvant être stockés dans le champ. Tous les chiffres sont comptabilisés, qu’ils se trouvent à gauche ou à droite de la virgule.

La valeur de paramètre est valide uniquement pour les champs de type numérique.

Long
field_scale
(Facultatif)

Nombre de décimales stockées dans un champ. Ce paramètre est uniquement utilisé dans les types de champs de données flottants et doubles.

Long
field_length
(Facultatif)

Longueur du champ en cours d’ajout. Définit le nombre maximal de caractères autorisés pour chaque enregistrement du champ. Ce paramètre est uniquement applicable aux champs de type texte.

Long
field_alias
(Facultatif)

Autre nom donné au champ. Ce nom sert à décrire les noms de champs sibyllins. Ce paramètre s’applique uniquement aux géodatabases.

String
field_is_nullable
(Facultatif)

Indique si le champ peut contenir des valeurs Null (nulles). Les valeurs Null sont différentes de zéro ou les champs vides sont uniquement pris en charge pour les champs d’une géodatabase.

  • NON_NULLABLE —Le champ n’autorise pas les valeurs Null.
  • NULLABLE —Le champ autorise les valeurs Null. Il s’agit de l’option par défaut.
Boolean

Sortie dérivée

NomExplicationType de données
output_layer

Couche d’analyse de réseau mise à jour.

Couche Network Analyst

Exemple de code

Exemple 1 d'utilisation de l'outil Ajouter un champ à la couche d'analyse (fenêtre Python)

Le script de fenêtre Python suivant montre comment ajouter un champ UniqueID à la sous-couche Facilities de la couche d’analyse de réseau Service Area.

arcpy.na.AddFieldToAnalysisLayer("Service Area", "Facilities", "UniqueID",
                                    "LONG")
Exemple 2 d'utilisation de l'outil Ajouter un champ à la couche d'analyse (workflow)

Le script Python autonome ci-dessous montre comment la fonction AddFieldToAnalysisLayer permet de transférer le champ StationID des entités de caserne de pompiers en entrée aux entités polygone de zone de desserte 2, 3 et 5 minutes calculées à partir d’une analyse des zones de desserte. Le champ StationID permet de joindre d’autres attributs des entités de caserne de pompiers aux entités polygones de zone de desserte.

# 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 occurred on line %i" % tb.tb_lineno
    print str(e)

Environnements

  • Espace de travail courant

Informations de licence

  • Basic: Oui
  • Standard: Oui
  • Advanced: Oui

Rubriques connexes

  • Vue d'ensemble du jeu d'outils Analyse

ArcGIS Desktop

  • Accueil
  • Documentation
  • Support

ArcGIS

  • ArcGIS Online
  • ArcGIS Desktop
  • ArcGIS Enterprise
  • ArcGIS
  • ArcGIS Developer
  • ArcGIS Solutions
  • ArcGIS Marketplace

A propos d'Esri

  • A propos de la société
  • Carrières
  • Blog d’Esri
  • Conférence des utilisateurs
  • Sommet des développeurs
Esri
Donnez-nous votre avis.
Copyright © 2021 Esri. | Confidentialité | Légal