Calcular campos (múltiple) (Administración de datos)

Resumen

Calcula los valores de dos o más campos para una clase de entidad, una capa de entidades o un ráster.

Uso

  • Para obtener más información sobre las expresiones de Python, consulte Ejemplos de Python de Calcular campo.

    Para obtener más información sobre las expresiones de Arcade, consulte la Guía de ArcGIS de Arcade.

    Para obtener más información sobre las expresiones de SQL, consulte Calcular valores de campo.

  • Cuando se utiliza con un conjunto seleccionado de entidades, como las creadas a partir de una consulta en la herramienta Crear capa de entidades o Seleccionar capa por atributo, esta herramienta solamente actualiza los registros seleccionados.

  • Los valores de campo existentes se sobrescriben. Realice una copia de la tabla de entrada si desea conservar los valores originales.

  • En los cálculos en Python, los nombres de campo deben estar entre signos de admiración (por ejemplo, !fieldname!).

    En los cálculos de Arcade, los nombres de campo deben tener el prefijo $feature. (por ejemplo, $feature.fieldname).

  • Para calcular cadenas para campos de texto o de caracteres, en el cuadro de diálogo la cadena debe estar entre comillas dobles ("cadena") y, en un script, la cadena entre comillas dobles también debe estar entre comillas simples (por ejemplo, '"string"').

  • Si desea calcular un campo para que sea un valor numérico, introduzca el valor numérico en el parámetro Expresión sin comillas alrededor del valor.

  • Puede crear expresiones complejas utilizando el parámetro Bloque de código. Introduzca el bloque de código directamente en el cuadro de diálogo o como una cadena en el script. La expresión y el bloque de código están conectados. El bloque de código debe estar relacionado con la expresión; el resultado del bloque de código debe entregarse a la expresión.

    El parámetro Bloque de código solo se admite en expresiones de Python.

  • Puede utilizar el módulo de Python math y formateo en el parámetro Bloque de código. También puede importar módulos adicionales. El módulo math proporciona funciones de representación y de teoría de números, funciones potencia y logarítmicas, funciones trigonométricas, funciones de conversión angular, funciones hiperbólicas y constantes matemáticas. Para obtener más información sobre el módulo math, consulte la Ayuda de Python.

  • Se pueden crear expresiones en Python utilizando las propiedades del objeto Geometry, como type, extent, centroid, firstPoint, lastPoint, area, length, isMultipart y partCount (por ejemplo, !shape.area!).

  • Puede utilizar las propiedades area y length de geometría en las expresiones Python con una unidad lineal o de área para convertir el valor a otra unidad de medida (por ejemplo, !shape.length@kilometers!). Si los datos se almacenan en un sistema de coordenadas geográficas y se proporciona una unidad lineal (por ejemplo, millas), la longitud se calculará mediante un algoritmo geodésico. El uso de unidades de área en los datos geográficos producirá resultados cuestionables, ya que los grados decimales no son iguales en todo el mundo.

    Más información sobre las herramientas de geoprocesamiento y las unidades lineales y de área

  • Se pueden usar expresiones de Python para calcular la longitud o el área geodésica de una entidad mediante el uso de las propiedades geodesicArea o geodesicLength combinadas con unidades de medida lineales o de área (por ejemplo, !shape.geodesicArea@hectares! o !shape.geodesicLength@miles!).

  • Cuando calcula datos unidos, no puede calcular directamente las columnas unidas. Sin embargo, puede calcular directamente las columnas de la tabla de origen. Para calcular los datos unidos, primero agregue las tablas o capas unidas al mapa. Después puede realizar cálculos en estos datos por separado. Estos cambios se reflejarán en las columnas que se unieron.

  • Las expresiones de Python que intentan concatenar campos de cadena de caracteres que incluyen un nulo o dividen entre un valor cero devolverán un nulo para ese valor de campo.

  • Las expresiones SQL permiten cálculos más rápidos en servicios de entidades y geodatabases corporativas. En lugar de realizar cálculos entidad por entidad o fila por fila, se define una sola solicitud para el servidor o la base de datos, lo cual genera cálculos más rápido.

    Solamente los servicios de entidades y las geodatabases corporativas son compatibles con expresiones de SQL. Para otros formatos, utilice expresiones de Python o Arcade.

    El uso de la opción SQL para el parámetro Tipo de expresión presenta las siguientes limitaciones:

    • La opción solo se admite con geodatabases corporativas de Db2, Oracle, PostgreSQL, SAP HANA y SQL Server.
    • No se admite el cálculo de valores de campo en tablas unidas.
    • Los datos versionados y archivados no son compatibles.
    • No se admite la función de deshacer operaciones de geoprocesamiento.

    Consulte la ayuda de las expresiones SQL en la documentación del proveedor de base de datos.

Parámetros

EtiquetaExplicaciónTipo de datos
Tabla de entrada

Tabla que contiene los campos que se actualizarán con los cálculos nuevos.

Table View; Raster Layer; Mosaic Layer
Tipo de expresión

Especifica el tipo de expresión que se utilizará.

Para obtener más información sobre las expresiones de Python, consulte Ejemplos de Python de Calcular campo.

Para obtener más información sobre las expresiones de Arcade, consulte la Guía de ArcGIS de Arcade.

Para obtener más información sobre las expresiones de SQL, consulte Calcular valores de campo.

  • Python 3Se utilizará el tipo de expresión de Python. Esta es la opción predeterminada.
  • ArcadeSe utilizará el tipo de expresión de Arcade.
  • SQLSe utilizará el tipo de expresión de SQL.
String
Campos

Los campos que se calcularán y sus expresiones.

Value Table
Bloque que código
(Opcional)

Un bloque de código que se utilizará para expresiones complejas.

No se puede utilizar una función para devolver varios valores.

String
Aplicar dominios
(Opcional)

Especifica si se aplican reglas de dominio de campo.

  • Activado: se aplican reglas de dominio de campo. Si un campo no se puede actualizar, el valor del campo no se modifica y los mensajes de la herramienta incluyen un mensaje de advertencia.
  • Desactivado: no se aplican reglas de dominio de campo. Esta es la configuración predeterminada
Boolean

Salida derivada

EtiquetaExplicaciónTipo de datos
Tabla de Salida

Las tablas actualizadas.

Table View; Raster Layer; Mosaic Layer

arcpy.management.CalculateFields(in_table, expression_type, fields, {code_block}, {enforce_domains})
NombreExplicaciónTipo de datos
in_table

Tabla que contiene los campos que se actualizarán con los cálculos nuevos.

Table View; Raster Layer; Mosaic Layer
expression_type

Especifica el tipo de expresión que se utilizará.

  • PYTHON3Se utilizará el tipo de expresión de Python. Esta es la opción predeterminada.
  • ARCADESe utilizará el tipo de expresión de Arcade.
  • SQLSe utilizará el tipo de expresión de SQL.

Para obtener más información sobre las expresiones de Python, consulte Ejemplos de Python de Calcular campo.

Para obtener más información sobre las expresiones de Arcade, consulte la Guía de ArcGIS de Arcade.

Para obtener más información sobre las expresiones de SQL, consulte Calcular valores de campo.

String
fields
[[Field Name, Expression],...]

Los campos que se calcularán y sus expresiones.

Value Table
code_block
(Opcional)

Un bloque de código que se utilizará para expresiones complejas.

No se puede utilizar una función para devolver varios valores.

String
enforce_domains
(Opcional)

Especifica si se aplican reglas de dominio de campo.

  • ENFORCE_DOMAINSSe aplican reglas de dominio de campo.
  • NO_ENFORCE_DOMAINSNo se aplican reglas de dominio de campo. Esta es la opción predeterminada.
Boolean

Salida derivada

NombreExplicaciónTipo de datos
out_table

Las tablas actualizadas.

Table View; Raster Layer; Mosaic Layer

Muestra de código

Ejemplo 1 de CalculateFields (ventana de Python)

El siguiente script de la ventana de Python demuestra cómo utilizar la función CalculateFields en el modo inmediato con el tipo de expresión de Python.

import arcpy
arcpy.env.workspace = "C:/data/airport.gdb"
arcpy.CalculateFields_management("parcels", "PYTHON3", 
                                 [["xCentroid", "!SHAPE.CENTROID.X!"], 
                                  ["yCentroid", "!SHAPE.CENTROID.Y!"]])
Ejemplo 2 de CalculateFields (ventana de Python)

El siguiente script de la ventana de Python demuestra cómo utilizar la función CalculateFields en el modo inmediato con el tipo de expresión SQL.

import arcpy
arcpy.CalculateFields_management("<a feature service url>", "SQL", 
                                 [["ceiling_field", "CEILING(field1)"], 
                                  ["floor_field", "FLOOR(field1)"]])
Ejemplo 3 de CalculateFields (ventana de Python)

El siguiente script de la ventana de Python demuestra cómo utilizar la función CalculateFields en el modo inmediato con el tipo de expresión de Arcade.

import arcpy
arcpy.env.workspace = "C:/data/airport.gdb"
arcpy.CalculateFields_management(
    "parcels", "ARCADE", 
    [["max_value", "Max($feature.field1, $feature.field2)"], 
     ["min_value", "Min($feature.field1, $feature.field2)"]])

Información de licenciamiento

  • Basic: Sí
  • Standard: Sí
  • Advanced: Sí

Temas relacionados