yq/operators/alternative-default-value.md

82 lines
1021 B
Markdown
Raw Normal View History

2021-10-30 03:14:39 +00:00
# Alternative (Default value)
This operator is used to provide alternative (or default) values when a particular expression is either null or false.
2022-02-06 03:41:27 +00:00
{% hint style="warning" %}
Note that versions prior to 4.18 require the 'eval/e' command to be specified. 
`yq e <exp> <file>`
{% endhint %}
2021-10-30 03:14:39 +00:00
## LHS is defined
Given a sample.yml file of:
```yaml
a: bridge
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '.a // "hello"' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
bridge
```
## LHS is not defined
Given a sample.yml file of:
```yaml
{}
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '.a // "hello"' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
hello
```
## LHS is null
Given a sample.yml file of:
```yaml
a: ~
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '.a // "hello"' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
hello
```
## LHS is false
Given a sample.yml file of:
```yaml
a: false
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '.a // "hello"' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
hello
```
## RHS is an expression
Given a sample.yml file of:
```yaml
a: false
b: cat
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '.a // .b' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
cat
```
2021-10-30 03:40:51 +00:00