mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-24 23:35:40 +00:00
247 lines
3.7 KiB
Markdown
247 lines
3.7 KiB
Markdown
# Boolean Operators
|
|
|
|
The `or` and `and` operators take two parameters and return a boolean result.
|
|
|
|
`not` flips a boolean from true to false, or vice versa.
|
|
|
|
`any` will return `true` if there are any `true` values in an array sequence, and `all` will return true if _all_ elements in an array are true.
|
|
|
|
`any_c(condition)` and `all_c(condition)` are like `any` and `all` but they take a condition expression that is used against each element to determine if it's `true`. Note: in `jq` you can simply pass a condition to `any` or `all` and it simply works - `yq` isn't that clever..yet
|
|
|
|
These are most commonly used with the `select` operator to filter particular nodes.
|
|
|
|
## Related Operators
|
|
|
|
- equals / not equals (`==`, `!=`) operators [here](https://mikefarah.gitbook.io/yq/operators/equals)
|
|
- comparison (`>=`, `<` etc) operators [here](https://mikefarah.gitbook.io/yq/operators/compare)
|
|
- select operator [here](https://mikefarah.gitbook.io/yq/operators/select)
|
|
|
|
## `or` example
|
|
Running
|
|
```bash
|
|
yq --null-input 'true or false'
|
|
```
|
|
will output
|
|
```yaml
|
|
true
|
|
```
|
|
|
|
## "yes" and "no" are strings
|
|
In the yaml 1.2 standard, support for yes/no as booleans was dropped - they are now considered strings. See '10.2.1.2. Boolean' in https://yaml.org/spec/1.2.2/
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- yes
|
|
- no
|
|
```
|
|
then
|
|
```bash
|
|
yq '.[] | tag' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
!!str
|
|
!!str
|
|
```
|
|
|
|
## `and` example
|
|
Running
|
|
```bash
|
|
yq --null-input 'true and false'
|
|
```
|
|
will output
|
|
```yaml
|
|
false
|
|
```
|
|
|
|
## Matching nodes with select, equals and or
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- a: bird
|
|
b: dog
|
|
- a: frog
|
|
b: bird
|
|
- a: cat
|
|
b: fly
|
|
```
|
|
then
|
|
```bash
|
|
yq '[.[] | select(.a == "cat" or .b == "dog")]' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- a: bird
|
|
b: dog
|
|
- a: cat
|
|
b: fly
|
|
```
|
|
|
|
## `any` returns true if any boolean in a given array is true
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- false
|
|
- true
|
|
```
|
|
then
|
|
```bash
|
|
yq 'any' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
true
|
|
```
|
|
|
|
## `any` returns false for an empty array
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
[]
|
|
```
|
|
then
|
|
```bash
|
|
yq 'any' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
false
|
|
```
|
|
|
|
## `any_c` returns true if any element in the array is true for the given condition.
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
- rad
|
|
- awesome
|
|
b:
|
|
- meh
|
|
- whatever
|
|
```
|
|
then
|
|
```bash
|
|
yq '.[] |= any_c(. == "awesome")' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: true
|
|
b: false
|
|
```
|
|
|
|
## `all` returns true if all booleans in a given array are true
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- true
|
|
- true
|
|
```
|
|
then
|
|
```bash
|
|
yq 'all' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
true
|
|
```
|
|
|
|
## `all` returns true for an empty array
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
[]
|
|
```
|
|
then
|
|
```bash
|
|
yq 'all' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
true
|
|
```
|
|
|
|
## `all_c` returns true if all elements in the array are true for the given condition.
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
- rad
|
|
- awesome
|
|
b:
|
|
- meh
|
|
- 12
|
|
```
|
|
then
|
|
```bash
|
|
yq '.[] |= all_c(tag == "!!str")' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: true
|
|
b: false
|
|
```
|
|
|
|
## Not true is false
|
|
Running
|
|
```bash
|
|
yq --null-input 'true | not'
|
|
```
|
|
will output
|
|
```yaml
|
|
false
|
|
```
|
|
|
|
## Not false is true
|
|
Running
|
|
```bash
|
|
yq --null-input 'false | not'
|
|
```
|
|
will output
|
|
```yaml
|
|
true
|
|
```
|
|
|
|
## String values considered to be true
|
|
Running
|
|
```bash
|
|
yq --null-input '"cat" | not'
|
|
```
|
|
will output
|
|
```yaml
|
|
false
|
|
```
|
|
|
|
## Empty string value considered to be true
|
|
Running
|
|
```bash
|
|
yq --null-input '"" | not'
|
|
```
|
|
will output
|
|
```yaml
|
|
false
|
|
```
|
|
|
|
## Numbers are considered to be true
|
|
Running
|
|
```bash
|
|
yq --null-input '1 | not'
|
|
```
|
|
will output
|
|
```yaml
|
|
false
|
|
```
|
|
|
|
## Zero is considered to be true
|
|
Running
|
|
```bash
|
|
yq --null-input '0 | not'
|
|
```
|
|
will output
|
|
```yaml
|
|
false
|
|
```
|
|
|
|
## Null is considered to be false
|
|
Running
|
|
```bash
|
|
yq --null-input '~ | not'
|
|
```
|
|
will output
|
|
```yaml
|
|
true
|
|
```
|
|
|