content/flux/v0/stdlib/universe/group.md
group() regroups input data by modifying group key of input tables.
Note: Group does not guarantee sort order.
To ensure data is sorted correctly, use sort() after group().
(<-tables: stream[A], ?columns: [string], ?mode: string) => stream[A] where A: Record
{{% caption %}} For more information, see Function type signatures. {{% /caption %}}
List of columns to use in the grouping operation. Default is [].
Note: When columns is set to an empty array, group() ungroups
all data merges it into a single output table.
Grouping mode. Default is by.
Available modes:
columns parameter.columns parameter.Input data. Default is piped-forward data (<-).
import "sampledata"
sampledata.int()
|> group(columns: ["_time", "tag"])
{{< expand-wrapper >}} {{% expand "View example input and output" %}}
| _time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | -2 | t1 |
| 2021-01-01T00:00:10Z | 10 | t1 |
| 2021-01-01T00:00:20Z | 7 | t1 |
| 2021-01-01T00:00:30Z | 17 | t1 |
| 2021-01-01T00:00:40Z | 15 | t1 |
| 2021-01-01T00:00:50Z | 4 | t1 |
| _time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | 19 | t2 |
| 2021-01-01T00:00:10Z | 4 | t2 |
| 2021-01-01T00:00:20Z | -3 | t2 |
| 2021-01-01T00:00:30Z | 19 | t2 |
| 2021-01-01T00:00:40Z | 13 | t2 |
| 2021-01-01T00:00:50Z | 1 | t2 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | -2 | t1 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | 19 | t2 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:10Z | 10 | t1 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:10Z | 4 | t2 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:20Z | 7 | t1 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:20Z | -3 | t2 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:30Z | 17 | t1 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:30Z | 19 | t2 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:40Z | 15 | t1 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:40Z | 13 | t2 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:50Z | 4 | t1 |
| *_time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:50Z | 1 | t2 |
{{% /expand %}} {{< /expand-wrapper >}}
import "sampledata"
sampledata.int()
|> group(columns: ["_time"], mode: "except")
{{< expand-wrapper >}} {{% expand "View example input and output" %}}
| _time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | -2 | t1 |
| 2021-01-01T00:00:10Z | 10 | t1 |
| 2021-01-01T00:00:20Z | 7 | t1 |
| 2021-01-01T00:00:30Z | 17 | t1 |
| 2021-01-01T00:00:40Z | 15 | t1 |
| 2021-01-01T00:00:50Z | 4 | t1 |
| _time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | 19 | t2 |
| 2021-01-01T00:00:10Z | 4 | t2 |
| 2021-01-01T00:00:20Z | -3 | t2 |
| 2021-01-01T00:00:30Z | 19 | t2 |
| 2021-01-01T00:00:40Z | 13 | t2 |
| 2021-01-01T00:00:50Z | 1 | t2 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:20Z | -3 | t2 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | -2 | t1 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:50Z | 1 | t2 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:50Z | 4 | t1 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:10Z | 4 | t2 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:20Z | 7 | t1 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:10Z | 10 | t1 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:40Z | 13 | t2 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:40Z | 15 | t1 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:30Z | 17 | t1 |
| _time | *_value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | 19 | t2 |
| 2021-01-01T00:00:30Z | 19 | t2 |
{{% /expand %}} {{< /expand-wrapper >}}
import "sampledata"
// Merge all tables into a single table
sampledata.int()
|> group()
{{< expand-wrapper >}} {{% expand "View example input and output" %}}
| _time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | -2 | t1 |
| 2021-01-01T00:00:10Z | 10 | t1 |
| 2021-01-01T00:00:20Z | 7 | t1 |
| 2021-01-01T00:00:30Z | 17 | t1 |
| 2021-01-01T00:00:40Z | 15 | t1 |
| 2021-01-01T00:00:50Z | 4 | t1 |
| _time | _value | *tag |
|---|---|---|
| 2021-01-01T00:00:00Z | 19 | t2 |
| 2021-01-01T00:00:10Z | 4 | t2 |
| 2021-01-01T00:00:20Z | -3 | t2 |
| 2021-01-01T00:00:30Z | 19 | t2 |
| 2021-01-01T00:00:40Z | 13 | t2 |
| 2021-01-01T00:00:50Z | 1 | t2 |
| _time | _value | tag |
|---|---|---|
| 2021-01-01T00:00:00Z | -2 | t1 |
| 2021-01-01T00:00:10Z | 10 | t1 |
| 2021-01-01T00:00:20Z | 7 | t1 |
| 2021-01-01T00:00:30Z | 17 | t1 |
| 2021-01-01T00:00:40Z | 15 | t1 |
| 2021-01-01T00:00:50Z | 4 | t1 |
| 2021-01-01T00:00:00Z | 19 | t2 |
| 2021-01-01T00:00:10Z | 4 | t2 |
| 2021-01-01T00:00:20Z | -3 | t2 |
| 2021-01-01T00:00:30Z | 19 | t2 |
| 2021-01-01T00:00:40Z | 13 | t2 |
| 2021-01-01T00:00:50Z | 1 | t2 |
{{% /expand %}} {{< /expand-wrapper >}}