JSON PATH
Query language for json
Dictionaries
$
is root element.
Query price via $.car.price
:
Lists
Query via $[INDEX]
:
$[0]
is [1]
can do multiple: [0,2]
is [1,3]
Can slice via [START:END_EXCLUSIVE]
Can step via [START:END_EXCLUSIVE:STEP]
Can get last via [-1]
or [-1:]
Criteria
More complex queries
?()
for query.
@
each item in list
So, get items > 2
:
Result: [3,4]
Can use ==
, !=
, in
, nin
Can check strings via ?(@.SOME_KEY == "val")
Wildcards
We can also use wildcards, eg all matches:
Or with Dictionaries:
JSON PATH in Kubernetes
$
is added if not there.
We can combine queries for multiple results:
We can prettify via { "\n" }
between queries.
We can loop with a {range .items[*]}{ ... }{ end }
, and access internal elements inside.
Can also create custom columns via -o=custom-columns=COL_NAME:JSON_PATH
Last updated