Contains
This returns true if the context contains the passed in parameter, and false otherwise. For arrays, this will return true if the passed in array is contained within the array. For strings, it will return true if the string is a substring.
Note that, just like jq, when checking if an array of strings contains another, this will use contains and not equals to check each string. This means an expression like contains(["cat"]) will return true for an array ["cats"].
See the "Array has a subset array" example below on how to check for a subset.
Array contains array
Array is equal or subset of
Given a sample.yml file of:
- foobar
- foobaz
- blarpthen
yq 'contains(["baz", "bar"])' sample.ymlwill output
trueArray has a subset array
Subtract the superset array from the subset, if there's anything left, it's not a subset
Given a sample.yml file of:
- foobar
- foobaz
- blarpthen
yq '["baz", "bar"] - . | length == 0' sample.ymlwill output
falseObject included in array
Given a sample.yml file of:
"foo": 12
"bar":
  - 1
  - 2
  - "barp": 12
    "blip": 13then
yq 'contains({"bar": [{"barp": 12}]})' sample.ymlwill output
trueObject not included in array
Given a sample.yml file of:
"foo": 12
"bar":
  - 1
  - 2
  - "barp": 12
    "blip": 13then
yq 'contains({"foo": 12, "bar": [{"barp": 15}]})' sample.ymlwill output
falseString contains substring
Given a sample.yml file of:
foobarthen
yq 'contains("bar")' sample.ymlwill output
trueString equals string
Given a sample.yml file of:
meowthen
yq 'contains("meow")' sample.ymlwill output
trueLast updated
Was this helpful?