yq/pkg/yqlib/doc/Recursive Descent (Glob).md

155 lines
2.5 KiB
Markdown
Raw Permalink Normal View History

2021-01-08 00:59:49 +00:00
This operator recursively matches (or globs) all children nodes given of a particular element, including that node itself. This is most often used to apply a filter recursively against all matches. It can be used in either the
2020-12-28 00:24:42 +00:00
## match values form `..`
This will, like the `jq` equivalent, recursively match all _value_ nodes. Use it to find/manipulate particular values.
For instance to set the `style` of all _value_ nodes in a yaml doc, excluding map keys:
2020-11-17 22:44:16 +00:00
```bash
2020-11-19 05:45:05 +00:00
yq eval '.. style= "flow"' file.yaml
2020-11-17 22:44:16 +00:00
```
2020-12-28 00:24:42 +00:00
## match values and map keys form `...`
The also includes map keys in the results set. This is particularly useful in YAML as unlike JSON, map keys can have their own styling, tags and use anchors and aliases.
For instance to set the `style` of all nodes in a yaml doc, including the map keys:
```bash
yq eval '... style= "flow"' file.yaml
```
## Recurse map (values only)
Given a sample.yml file of:
```yaml
a: frog
```
then
```bash
yq eval '..' sample.yml
```
will output
```yaml
a: frog
frog
```
2021-01-08 01:11:29 +00:00
## Recursively find nodes with keys
2021-01-10 00:27:18 +00:00
Note that this example has wrapped the expression in `[]` to show that there are two matches returned. You do not have to wrap in `[]` in your path expression.
2021-01-08 01:11:29 +00:00
Given a sample.yml file of:
```yaml
a:
name: frog
b:
name: blog
age: 12
```
then
```bash
2021-01-10 00:27:18 +00:00
yq eval '[.. | select(has("name"))]' sample.yml
2021-01-08 01:11:29 +00:00
```
will output
```yaml
2021-01-10 00:27:18 +00:00
- name: frog
b:
name: blog
age: 12
- name: blog
2021-01-08 01:11:29 +00:00
age: 12
```
## Recursively find nodes with values
Given a sample.yml file of:
```yaml
a:
nameA: frog
b:
nameB: frog
age: 12
```
then
```bash
yq eval '.. | select(. == "frog")' sample.yml
```
will output
```yaml
frog
frog
```
2020-12-28 00:24:42 +00:00
## Recurse map (values and keys)
Note that the map key appears in the results
Given a sample.yml file of:
```yaml
a: frog
```
then
```bash
yq eval '...' sample.yml
```
will output
```yaml
a: frog
a
frog
```
2020-11-22 02:16:54 +00:00
## Aliases are not traversed
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
a: &cat
c: frog
b: *cat
```
then
```bash
2020-11-22 02:16:54 +00:00
yq eval '[..]' sample.yml
2020-11-17 22:44:16 +00:00
```
will output
```yaml
2020-11-22 02:16:54 +00:00
- a: &cat
c: frog
b: *cat
- &cat
2020-11-17 22:44:16 +00:00
c: frog
2020-11-22 02:16:54 +00:00
- frog
- *cat
2020-11-17 22:44:16 +00:00
```
2020-11-22 02:16:54 +00:00
## Merge docs are not traversed
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
foo: &foo
a: foo_a
thing: foo_thing
c: foo_c
bar: &bar
b: bar_b
thing: bar_thing
c: bar_c
foobarList:
b: foobarList_b
!!merge <<:
- *foo
- *bar
c: foobarList_c
foobar:
c: foobar_c
!!merge <<: *foo
thing: foobar_thing
```
then
```bash
2020-11-22 02:16:54 +00:00
yq eval '.foobar | [..]' sample.yml
2020-11-17 22:44:16 +00:00
```
will output
```yaml
2020-11-22 02:16:54 +00:00
- c: foobar_c
!!merge <<: *foo
thing: foobar_thing
- foobar_c
- *foo
- foobar_thing
2020-11-17 22:44:16 +00:00
```