Combinación 3D (3D Analyst)

Resumen

Fusiona entidades multiparche cerradas superpuestas desde una clase de entidad de entrada.

Ilustración

Union 3D

Uso

Sintaxis

Union3D_3d (in_feature_class, {group_field}, out_feature_class, {out_table}, {disable_optimization}, {output_all})
ParámetroExplicaciónTipo de datos
in_feature_class

Las entidades multiparche cerradas que se intersecarán y agregarán.

Feature Layer
group_field
(Opcional)

El campo que se utiliza para identificar las entidades que se deben agrupar.

Field
out_feature_class

La clase de entidad multiparche de salida que almacenará las entidades agregadas.

Feature Class
out_table
(Opcional)

Una tabla de uno a muchos que representa la relación entre las entidades de entrada y sus equivalentes agregados.

Table
disable_optimization
(Opcional)

Especifica si la optimización se llevará a cabo automáticamente o se deshabilitará:

  • ENABLEDLa optimización se realiza en los datos de entrada. La herramienta hará un preprocesamiento para detectar qué entidades pueden superponerse al agruparlas, para mejorar el rendimiento y crear salidas únicas para cada conjunto de entidades superpuestas. Esta es la opción predeterminada.
  • DISABLEDNo se realiza optimización en los datos de entrada. La entidad será de combinación de acuerdo con su campo de agrupación, o todas las entidades se combinarán en una entidad de salida única.
Boolean
output_all
(Opcional)

Determina si la clase de entidad de salida contiene todas las entidades o solo las superpuestas que fueron combinadas.

  • DISABLEDSolo las entidades combinadas se escriben en la salida.
  • ENABLEDTodas las entidades de entrada se escriben en la salida. Esta es la opción predeterminada.
Boolean

Ejemplo de código

Ejemplo 1 de Union3D (ventana de Python)

El siguiente ejemplo muestra cómo usar de esta herramienta en la ventana Python:

import arcpy
from arcpy import env

arcpy.CheckOutExtension('3D')
env.workspace = 'C:/data'
arcpy.Union3D_3d('multipatch.shp', 'union_output.shp', 'GROUP_FIELD', 
                'DISABLE', 'ENABLE', 'UnionTable.dbf')
Ejemplo 2 de Union3D (secuencia de comandos independiente)

El siguiente ejemplo muestra cómo usar esta herramienta en una secuencia de comandos independiente de Python:

'''****************************************************************************
Name: Union3D Example
Description: This script demonstrates how to use the 
             Union3D tool.
****************************************************************************'''
# Import system modules
import arcpy
import exceptions, sys, traceback
from arcpy import env

try:
    arcpy.CheckOutExtension('3D')
    # Set environment settings
    env.workspace = 'C:/data'
    # Set Local Variables
    inMP = "multipatch.shp"
    # Ensure output multipatch has a unique name
    outMP = arcpy.CreateUniqueName("union_output.shp")
    outTbl = arcpy.CreateUniqueName("UnionTable.dbf")
    GroupField = "Type"
    optimize = "DISABLE"
    solids = "ENABLE"
    #Execute Union3D
    arcpy.ddd.Union3D(inMP, outMP, GroupField, optimize, solids, outTbl)
    arcpy.CheckInExtension('3D')


except arcpy.ExecuteError:
    print arcpy.GetMessages()
except:
    # Get the traceback object
    tb = sys.exc_info()[2]
    tbinfo = traceback.format_tb(tb)[0]
    # Concatenate error information into message string
    pymsg = 'PYTHON ERRORS:\nTraceback info:\n{0}\nError Info:\n{1}'\
          .format(tbinfo, str(sys.exc_info()[1]))
    msgs = 'ArcPy ERRORS:\n {0}\n'.format(arcpy.GetMessages(2))
    # Return python error messages for script tool or Python Window
    arcpy.AddError(pymsg)
    arcpy.AddError(msgs)

Entornos

Temas relacionados

9/11/2013