Domaine vers table (Gestion des données)
Récapitulatif
Crée une table à partir d'un domaine attributaire.
Utilisation
-
La création d'une table à partir d'un domaine attributaire permet la mise à jour additionnelle de la table dans ArcMap. Par exemple, une table peut être créée à partir d'un domaine de valeurs précodées, des valeurs précodées supplémentaires peuvent être ajoutés à la liste de valeurs précodées et l'outil Table vers domaine peut permettre de mettre à jour le domaine original.
-
Les domaines d'espace de travail peuvent également être gérés dans ArcCatalog ou la fenêtre Catalogue. Les domaines peuvent être créés et modifiés dans l'onglet Domaines de la boîte de dialogue Propriétés de la base de données.
Syntaxe
Paramètre | Explication | Type de données |
in_workspace |
Espace de travail contenant le domaine attributaire à convertir en table. | Workspace |
domain_name |
Nom du domaine attributaire existant. | String |
out_table |
Table à créer. | Table |
code_field |
Nom du champ de la table créée qui stocke les valeurs de code. | String |
description_field |
Nom du champ de la table créée qui stocke les descriptions des valeurs de code. | String |
configuration_keyword (Facultatif) |
Pour les tables SDE, mot-clé de stockage personnalisé pour la création de la table. | String |
Exemple de code
Le script de fenêtre Python ci-dessous illustre l'utilisation de la fonction DomainToTable en mode immédiat.
import arcpy
from arcpy import env
env.workspace = "C:/data"
arcpy.DomainToTable_management("montgomery.gdb", "DistDiam", "diameters", "code", "descript")
Ce script autonome utilise la fonction DomainToTable dans le cadre d'un workflow pour modifier un domaine.
# Name: RemoveDomainsExample.py
# Purpose: Update an attribute domain to constrain valid pipe material values
# Author: ESRI
# Import system modules
import arcpy, os
from arcpy import env
try:
# Set the workspace (to avoid having to type in the full path to the data every time)
env.workspace = "data"
# set local parameters
inFeatures = "Montgomery.gdb/Water/DistribMains"
inField = "MATERIAL"
dWorkspace = "Montgomery.gdb"
domName = "Material"
codedValue = "ACP: Asbestos concrete"
codeField = "TYPE"
fieldDesc= "DESRIPT"
# Process: Remove the constraint from the material field
arcpy.RemoveDomainFromField_management(inFeatures, inField)
# Edit the domain values
# Process: Remove a coded value from the domain
arcpy.DeleteCodedValueFromDomain_management(dWorkspace, domName, codedValue)
# Process: Create a table from the domain to edit it with ArcMap editing tools
arcpy.DomainToTable_management(dWorkspace, domname, dWorkspace + os.sep + domname , codeField, fieldDesc)
# Process: Delete the domain
arcpy.DeleteDomain_management(dWorkspace, domName)
# Edit the domain table outside of geoprocessing
# and then bring the domain back in with the TableToDomain process
except Exception, e:
# If an error occurred, print line number and error message
import traceback, sys
tb = sys.exc_info()[2]
print "Line %i" % tb.tb_lineno
print e.message