Recursive Descent (Glob)
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.
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:
yq '.. style= "flow"' file.yamlmatch 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 and tags and also use anchors and aliases.
For instance to set the style of all nodes in a yaml doc, including the map keys:
yq '... style= "flow"' file.yamlRecurse map (values only)
Given a sample.yml file of:
a: frogthen
yq '..' sample.ymlwill output
a: frog
frogRecursively find nodes with keys
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.
Given a sample.yml file of:
a:
name: frog
b:
name: blog
age: 12then
yq '[.. | select(has("name"))]' sample.ymlwill output
- name: frog
b:
name: blog
age: 12
- name: blog
age: 12Recursively find nodes with values
Given a sample.yml file of:
a:
nameA: frog
b:
nameB: frog
age: 12then
yq '.. | select(. == "frog")' sample.ymlwill output
frog
frogRecurse map (values and keys)
Note that the map key appears in the results
Given a sample.yml file of:
a: frogthen
yq '...' sample.ymlwill output
a: frog
a
frogAliases are not traversed
Given a sample.yml file of:
a: &cat
c: frog
b: *catthen
yq '[..]' sample.ymlwill output
- a: &cat
c: frog
b: *cat
- &cat
c: frog
- frog
- *catMerge docs are not traversed
Given a sample.yml file of:
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_thingthen
yq '.foobar | [..]' sample.ymlwill output
- c: foobar_c
!!merge <<: *foo
thing: foobar_thing
- foobar_c
- *foo
- foobar_thingLast updated
Was this helpful?