ItemSelector (Mapa) - AWS Step Functions

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

ItemSelector (Mapa)

Administrar el estado y transformar los datos

De forma predeterminada, la entrada efectiva para el estado Map es el conjunto de elementos de datos individuales presentes en la entrada de estado sin procesar. El campo ItemSelector permite anular los valores de los elementos de datos antes de que se transfieran al estado Map. Para anular los valores, especifique una entrada JSON válida que contenga un conjunto de pares clave-valor. Estos pares pueden ser valores estáticos proporcionados en la definición de la máquina de estados, valores seleccionados de la entrada de estado mediante una ruta o valores a los que se accede desde el objeto Context.

Si especifica pares clave-valor mediante una ruta o un objeto de contexto, el nombre de la clave debe terminar en. .$

nota

El campo ItemSelector reemplaza al campo Parameters dentro del estado Map. Si utiliza el campo Parameters en las definiciones de estado Map para crear entradas personalizadas, le recomendamos encarecidamente que lo sustituya por ItemSelector.

Puede especificar el campo ItemSelector tanto en un estado Map en línea como en un estado Map Distributed.

Por ejemplo, considere la siguiente entrada JSON que contiene una matriz de tres elementos dentro del nodo imageData. Por cada iteración del estado Map, se pasa un elemento de matriz a la iteración como entrada.

[ { "resize": "true", "format": "jpg" }, { "resize": "false", "format": "png" }, { "resize": "true", "format": "jpg" } ]

Con el campo ItemSelector, puede definir una entrada JSON personalizada para anular la entrada original, como se muestra en el siguiente ejemplo. Luego, Step Functions pasa esta entrada personalizada a cada iteración del estado Map. La entrada personalizada contiene un valor estático para el estado size y el valor de los datos de un objeto de Map contexto. El objeto $$.Map.Item.Value Context contiene el valor de cada elemento de datos individual.

{ "ItemSelector": { "size": 10, "value.$": "$$.Map.Item.Value" } }

El siguiente ejemplo muestra la entrada recibida por una iteración del estado Map en línea:

{ "size": 10, "value": { "resize": "true", "format": "jpg" } }
sugerencia

Para ver un ejemplo completo de un estado Map Distributed que usa el campo ItemSelector, consulte Copiar datos CSV a gran escala mediante Distributed Map.