# 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. ## Related Operators - comparison (`>=`, `<` etc) operators (here)[https://mikefarah.gitbook.io/yq/operators/compare] - boolean operators (`and`, `or`, `any` etc) (here)[https://mikefarah.gitbook.io/yq/operators/boolean-operators] - select operator (here)[https://mikefarah.gitbook.io/yq/operators/select] {% hint style="warning" %} Note that versions prior to 4.18 require the 'eval/e' command to be specified. `yq e ` {% endhint %} ## 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 ``` ## Dont 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 exisitant 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 ```