yq/pkg/yqlib/doc/Path.md
Mike Farah f7f8bed955 wip
2020-12-27 09:55:21 +11:00

1.3 KiB

The path operator can be used to get the traversal paths of matching nodes in an expression. The path is returned as an array, which if traversed in order will lead to the matching node.

You can get the key/index of matching nodes by using the path operator to return the path array then piping that through .[-1] to get the last element of that array, the key.

Map path

Given a sample.yml file of:

a: {b: cat}
'': null

then

yq eval '.a.b | path' sample.yml

will output

- a
- b

Get map key

Given a sample.yml file of:

a: {b: cat}
'': null

then

yq eval '.a.b | path | .[-1]' sample.yml

will output

b

Array path

Given a sample.yml file of:

a: [cat, dog]
'': null

then

yq eval '.a.[] | select(. == "dog") | path' sample.yml

will output

- a
- 1

Get array index

Given a sample.yml file of:

a: [cat, dog]
'': null

then

yq eval '.a.[] | select(. == "dog") | path | .[-1]' sample.yml

will output

1

Print path and value

Given a sample.yml file of:

a: [cat, dog, frog]
'': null

then

yq eval '.a.[] | select(. == "*og") | [{"path":path, "value":.}]' sample.yml

will output

- '': null
- '': null