mirror of
https://github.com/mikefarah/yq.git
synced 2024-12-19 20:19:04 +00:00
143 lines
1.8 KiB
Markdown
143 lines
1.8 KiB
Markdown
# Entries
|
|
|
|
Similar to the same named functions in `jq` these functions convert to/from an object and an array of key-value pairs. This is most useful for performing operations on keys of maps.
|
|
|
|
## to_entries Map
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
{a: 1, b: 2}
|
|
```
|
|
then
|
|
```bash
|
|
yq 'to_entries' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- key: a
|
|
value: 1
|
|
- key: b
|
|
value: 2
|
|
```
|
|
|
|
## to_entries Array
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
[a, b]
|
|
```
|
|
then
|
|
```bash
|
|
yq 'to_entries' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- key: 0
|
|
value: a
|
|
- key: 1
|
|
value: b
|
|
```
|
|
|
|
## to_entries null
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
[]
|
|
```
|
|
then
|
|
```bash
|
|
yq 'to_entries' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
[]
|
|
```
|
|
|
|
## from_entries map
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
{a: 1, b: 2}
|
|
```
|
|
then
|
|
```bash
|
|
yq 'to_entries | from_entries' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- a
|
|
- 1
|
|
- b
|
|
- 2
|
|
```
|
|
|
|
## from_entries with numeric key indices
|
|
from_entries always creates a map, even for numeric keys
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
[a, b]
|
|
```
|
|
then
|
|
```bash
|
|
yq 'to_entries | from_entries' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- 0
|
|
- a
|
|
- 1
|
|
- b
|
|
```
|
|
|
|
## Use with_entries to update keys
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
{a: 1, b: 2}
|
|
```
|
|
then
|
|
```bash
|
|
yq 'with_entries(.key |= "KEY_" + .)' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- KEY_a
|
|
- 1
|
|
- KEY_b
|
|
- 2
|
|
```
|
|
|
|
## Custom sort map keys
|
|
Use to_entries to convert to an array of key/value pairs, sort the array using sort/sort_by/etc, and convert it back.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
{a: 1, c: 3, b: 2}
|
|
```
|
|
then
|
|
```bash
|
|
yq 'to_entries | sort_by(.key) | reverse | from_entries' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
!!tag
|
|
- c
|
|
- 3
|
|
- b
|
|
- 2
|
|
- a
|
|
- 1
|
|
```
|
|
|
|
## Use with_entries to filter the map
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
{a: {b: bird}, c: {d: dog}}
|
|
```
|
|
then
|
|
```bash
|
|
yq 'with_entries(select(.value | has("b")))' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- a
|
|
- {b: bird}
|
|
```
|
|
|