Back to Yq

Equals / Not Equals

pkg/yqlib/doc/operators/equals.md

4.53.21.7 KB
Original Source

Equals / Not Equals

This is a boolean operator that will return true if the LHS is equal to the RHS and false otherwise.

.a == .b

It is most often used with the select operator to find particular nodes:

select(.a == .b)

The not equals != operator returns false if the LHS is equal to the RHS.

  • comparison (>=, < etc) operators here
  • boolean operators (and, or, any etc) here
  • select operator here

Match string

Given a sample.yml file of:

yaml
- cat
- goat
- dog

then

bash
yq '.[] | (. == "*at")' sample.yml

will output

yaml
true
true
false

Don't match string

Given a sample.yml file of:

yaml
- cat
- goat
- dog

then

bash
yq '.[] | (. != "*at")' sample.yml

will output

yaml
false
false
true

Match number

Given a sample.yml file of:

yaml
- 3
- 4
- 5

then

bash
yq '.[] | (. == 4)' sample.yml

will output

yaml
false
true
false

Don't match number

Given a sample.yml file of:

yaml
- 3
- 4
- 5

then

bash
yq '.[] | (. != 4)' sample.yml

will output

yaml
true
false
true

Match nulls

Running

bash
yq --null-input 'null == ~'

will output

yaml
true

Non existent key doesn't equal a value

Given a sample.yml file of:

yaml
a: frog

then

bash
yq 'select(.b != "thing")' sample.yml

will output

yaml
a: frog

Two non existent keys are equal

Given a sample.yml file of:

yaml
a: frog

then

bash
yq 'select(.b == .c)' sample.yml

will output

yaml
a: frog