Loop Over a List of Values
How to iterate over a list of values in your flow.
In this guide, you will learn how to iterate over a list of values using the ForEach
task. This task enables you to loop through a list of values and execute specific tasks for each value in the list. This approach is useful for scenarios where multiple similar tasks need to be run for different inputs.
Prerequisites
Before you begin:
- Deploy Kestra in your preferred development environment.
- Ensure you have a basic understanding of how to run Kestra flows.
Loop over nested lists of values
This example demonstrates how to use ForEach
to loop over a list of strings and then loop through a nested list for each string.
You can access the current iteration value using the variable {{ taskrun.value }}
or {{ parent.taskrun.value }}
if you are in a nested child task. Additionally, you can access the batch or iteration number with {{ taskrun.iteration }}
.
To see the flow in action, define the each_nested
flow as shown below:
id: each_nested
namespace: company.team
tasks:
- id: 1_each
type: io.kestra.plugin.core.flow.ForEach
values: '["s1", "s2", "s3"]'
tasks:
- id: 1-1_return
type: io.kestra.plugin.core.debug.Return
format: "{{task.id}} > {{taskrun.value}} > {{taskrun.startDate}}"
- id: 1-2_each
type: io.kestra.plugin.core.flow.ForEach
values: '["a a", "b b"]'
tasks:
- id: 1-2-1_return
type: io.kestra.plugin.core.debug.Return
format: "{{task.id}} > {{taskrun.value}} > {{taskrun.startDate}}"
- id: 1-2-2_return
type: io.kestra.plugin.core.debug.Return
format: "{{task.id}} > {{ outputs['1-2-1_return'].s1[taskrun.value].value }} >> get {{ outputs['1-2-1_return']['s1'][taskrun.value].value }} > {{taskrun.startDate}}"
- id: 1-3_return
type: io.kestra.plugin.core.debug.Return
format: "{{task.id}} > {{ outputs['1-1_return'][taskrun.value].value }} > {{taskrun.startDate}}"
- id: 2_return
type: io.kestra.plugin.core.debug.Return
format: "{{task.id}} > {{outputs['1-2-1_return'].s1['a a'].value}}"
Save and execute the each_nested
flow.
The above flow, when executed, iterates over a nested list of values, logging messages at each level of iteration to track the processing of both the outer and inner list items.
Within the flow:
1_each
: Uses theForEach
task to iterate over the list["s1", "s2", "s3"]
. For each value, it runs the nested tasks defined within.1-1_return
: Logs the task ID, the current list value, and the task run start time.1-2_each
: Iterates over a second list["a a", "b b"]
and runs a set of tasks for each value in this nested list.1-2-1_return
: Logs the task ID, the nested list value, and the start time of the task run.1-2-2_return
: Logs a custom output from1-2-1_return
, which shows how to access outputs from previous iterations within the nested loop.
1-3_return
: Logs the output from1-1_return
after the inner loop is completed and displays the corresponding value processed in the outer loop.
2_return
: Fetches the output from the nested loop (1-2-1_return
for the valuea a
) and logs it.
Next steps
Now that you've seen how to loop over a list of values using ForEach
, you can apply this technique to any scenario where multiple iterations of similar tasks are needed. You can further extend this flow by:
- Adding more complex nested loops.
- Using dynamic input values instead of hardcoded lists.
- Logging or processing additional data from each iteration.
For more advanced use cases, refer to Kestra’s official ForEach task documentation.
Was this page helpful?