2021-10-30 04:52:05 +00:00
|
|
|
# Flatten
|
|
|
|
This recursively flattens arrays.
|
|
|
|
|
|
|
|
## Flatten
|
|
|
|
Recursively flattens all arrays
|
|
|
|
|
|
|
|
Given a sample.yml file of:
|
|
|
|
```yaml
|
|
|
|
- 1
|
|
|
|
- - 2
|
|
|
|
- - - 3
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
2022-01-28 01:45:43 +00:00
|
|
|
yq 'flatten' sample.yml
|
2021-10-30 04:52:05 +00:00
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
- 1
|
|
|
|
- 2
|
|
|
|
- 3
|
|
|
|
```
|
|
|
|
|
|
|
|
## Flatten with depth of one
|
|
|
|
Given a sample.yml file of:
|
|
|
|
```yaml
|
|
|
|
- 1
|
|
|
|
- - 2
|
|
|
|
- - - 3
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
2022-01-28 01:45:43 +00:00
|
|
|
yq 'flatten(1)' sample.yml
|
2021-10-30 04:52:05 +00:00
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
- 1
|
|
|
|
- 2
|
|
|
|
- - 3
|
|
|
|
```
|
|
|
|
|
|
|
|
## Flatten empty array
|
|
|
|
Given a sample.yml file of:
|
|
|
|
```yaml
|
|
|
|
- []
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
2022-01-28 01:45:43 +00:00
|
|
|
yq 'flatten' sample.yml
|
2021-10-30 04:52:05 +00:00
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
[]
|
|
|
|
```
|
|
|
|
|
|
|
|
## Flatten array of objects
|
|
|
|
Given a sample.yml file of:
|
|
|
|
```yaml
|
|
|
|
- foo: bar
|
|
|
|
- - foo: baz
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
2022-01-28 01:45:43 +00:00
|
|
|
yq 'flatten' sample.yml
|
2021-10-30 04:52:05 +00:00
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
- foo: bar
|
|
|
|
- foo: baz
|
|
|
|
```
|
|
|
|
|