2022-03-10 02:50:03 +00:00
|
|
|
# Pick
|
|
|
|
|
|
|
|
Filter a map by the specified list of keys. Map is returned with the key in the order of the pick list.
|
|
|
|
|
|
|
|
Similarly, filter an array by the specified list of indices.
|
|
|
|
|
|
|
|
## Pick keys from map
|
|
|
|
Note that the order of the keys matches the pick order and non existent keys are skipped.
|
|
|
|
|
|
|
|
Given a sample.yml file of:
|
|
|
|
```yaml
|
|
|
|
myMap:
|
|
|
|
cat: meow
|
|
|
|
dog: bark
|
|
|
|
thing: hamster
|
2023-09-26 04:50:18 +00:00
|
|
|
hamster: squeak
|
2022-03-10 02:50:03 +00:00
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
|
|
|
yq '.myMap |= pick(["hamster", "cat", "goat"])' sample.yml
|
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
myMap:
|
2023-09-26 04:50:18 +00:00
|
|
|
hamster: squeak
|
2022-03-10 02:50:03 +00:00
|
|
|
cat: meow
|
|
|
|
```
|
|
|
|
|
2024-09-06 02:33:38 +00:00
|
|
|
## Pick keys from map, included all the keys
|
|
|
|
We create a map of the picked keys plus all the current keys, and run that through unique
|
|
|
|
|
|
|
|
Given a sample.yml file of:
|
|
|
|
```yaml
|
|
|
|
myMap:
|
|
|
|
cat: meow
|
|
|
|
dog: bark
|
|
|
|
thing: hamster
|
|
|
|
hamster: squeak
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
|
|
|
yq '.myMap |= pick( (["thing"] + keys) | unique)' sample.yml
|
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
myMap:
|
|
|
|
thing: hamster
|
|
|
|
cat: meow
|
|
|
|
dog: bark
|
|
|
|
hamster: squeak
|
|
|
|
```
|
|
|
|
|
2022-03-10 02:50:03 +00:00
|
|
|
## Pick indices from array
|
2023-03-18 03:54:23 +00:00
|
|
|
Note that the order of the indices matches the pick order and non existent indices are skipped.
|
2022-03-10 02:50:03 +00:00
|
|
|
|
|
|
|
Given a sample.yml file of:
|
|
|
|
```yaml
|
|
|
|
- cat
|
|
|
|
- leopard
|
|
|
|
- lion
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
|
|
|
yq 'pick([2, 0, 734, -5])' sample.yml
|
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
- lion
|
|
|
|
- cat
|
|
|
|
```
|
|
|
|
|