On October 30, 2022, all 1.2.x versions of the Splunk Data Stream Processor will reach its end of support date. See the Splunk Software Support Policy for details.
Iterator
The following scalar functions operate on an iterator. Use these functions to process or transform elements of a list.
filter(iterator, predicate)
Filters elements of the iterator
based on the boolean expression predicate
. You must use this function in conjunction with the iterator scalar function, as shown in the example.
- Function Input
- iterator: The function that defines the list to filter
- predicate: expression<boolean>. If this returns true, the value is kept. If false, it is discarded.
- Function Output
- collection<T>
- This function outputs a list of type T, where T is the element type of the iterator.
SPL2 example
If the incoming record has a field called list
containing the values [1, 2, 3, 4]
, return a new list in results
with the list [1, 2]
.
When working in the SPL View, you can write the function by using the following syntax.
...| eval results=filter(iterator(list, "x"), cast(x, "integer")<3);
Alternatively, you can use named arguments to list the arguments in any order.
...| eval results=filter(predicate: cast(x, "integer") < 3, iterator: iterator(list, "x"));
for_each(iterator, function)
For each element of iterator
, evaluate expression function
and return a new list containing the results. You must use this function in conjunction with the iterator scalar function, as shown in the example.
- Function Input
- iterator: The function that defines the list to transform.
- function: The function to apply to each element in the iteration.
- Function Output
- collection<R>
- This function outputs a list of type R, where R is the element type of the iterator or the data type associated with the mapper function.
1. SPL2 example
If the incoming record has a field called string_list containing the values ["a","b","c"]
, outputs a new list where each element of the list is prepended with foo_
: ["foo_a", "foo_b", "foo_c"]
.
When working in the SPL View, you can write the function by using the following syntax.
...| eval string_results=for_each(iterator(string_list, "x"), concat(["foo_", x]));
2. SPL2 example
If the input record has a field called list containing the values [1,2,3]
and the list type is long
, then the following example adds 100 to each value and puts the new list [101, 102, 103]
in a new field called results
.
When working in the SPL View, you can write the function by using the following syntax.
... | eval results=for_each(iterator(list, "numval"), add(cast(100, "long"), cast(numval, "long")));
3. SPL2 example
This example adds two new key-value pairs type
and unit
to the metrics map. If the incoming records have a body containing a list of metric maps such as Record{"body"=[{"name"="abc", "value"=123}, {"name"="xyz", "value"=789}]}
, then the following example adds type
and unit
to the metrics map Record{"body"=[{"name"="abc", "unit"="percent", "type"="g", "value"=123}, {"name"="xyz", "unit"="percent", "type"="g", "value"=789}]}
.
When working in the SPL View, you can write the function by using the following syntax.
...| eval body=for_each(iterator(map_list, "x"), map_set(x, ["type", "g", "unit", "percent"]));
4. SPL2 example
Alternatively, you can use named arguments to list the arguments in any order.
...| eval string_results=for_each(function: concat(["foo_", x]), iterator: iterator(string_list, "x"));
iterator(input, fieldname)
Iterates through a list input
and temporarily assigns each element in list input
as fieldname
. You must use this function in combination with the for_each or filter scalar functions.
- Function Input
- input: collection<R>
- fieldname: string
- Function Output
- list of any type T
Argument | Input | Description |
---|---|---|
input | collection<R> | A list of type T, where T is any type. For example, the input of this function can be a list of strings, list of numbers, list of maps, list of lists, or a list of mixed types. |
fieldname | string | A temporary or local variable name for each element in the list. Use this variable name to refer to the elements of this list when using the for_each or filter iterator functions.
|
SPL2 example
Prepends "foo_" to each element of string_list.
When working in the SPL View, you can write the function by using the following syntax.
...| eval string_results=for_each(iterator(string_list, "x"), concat(["foo_", x]));
Alternatively, you can use named arguments to list the arguments in any order.
...| eval string_results=for_each(iterator(fieldname: "x", input: string_list), concat(["foo_", x]));
Date and Time | List |
This documentation applies to the following versions of Splunk® Data Stream Processor: 1.2.0, 1.2.1-patch02, 1.2.1, 1.2.2-patch02, 1.2.4, 1.2.5, 1.3.0, 1.3.1, 1.4.0, 1.4.1, 1.4.2, 1.4.3, 1.4.4, 1.4.5
Feedback submitted, thanks!