2024-02-09 02:54:27 +00:00
|
|
|
# Formatting Expressions
|
|
|
|
|
|
|
|
`From version v4.41+`
|
|
|
|
|
|
|
|
You can put expressions into `.yq` files, use whitespace and comments to break up complex expressions and explain what's going on.
|
|
|
|
|
|
|
|
## Using expression files and comments
|
|
|
|
Given a sample.yaml file of:
|
|
|
|
```yaml
|
|
|
|
a:
|
|
|
|
b: old
|
|
|
|
```
|
|
|
|
And an 'update.yq' expression file of:
|
|
|
|
```bash
|
|
|
|
# This is a yq expression that updates the map
|
|
|
|
# for several great reasons outlined here.
|
|
|
|
|
|
|
|
.a.b = "new" # line comment here
|
|
|
|
| .a.c = "frog"
|
|
|
|
|
|
|
|
# Now good things will happen.
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
|
|
|
yq --from-file update.yq sample.yml
|
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
a:
|
|
|
|
b: new
|
|
|
|
c: frog
|
|
|
|
```
|
|
|
|
|
2024-02-09 02:58:59 +00:00
|
|
|
## Commenting out yq expressions
|
|
|
|
Note that `c` is no longer set to 'frog'.
|
|
|
|
|
|
|
|
Given a sample.yaml file of:
|
|
|
|
```yaml
|
|
|
|
a:
|
|
|
|
b: old
|
|
|
|
```
|
|
|
|
And an 'update.yq' expression file of:
|
|
|
|
```bash
|
|
|
|
# This is a yq expression that updates the map
|
|
|
|
# for several great reasons outlined here.
|
|
|
|
|
|
|
|
.a.b = "new" # line comment here
|
|
|
|
# | .a.c = "frog"
|
|
|
|
|
|
|
|
# Now good things will happen.
|
|
|
|
```
|
|
|
|
then
|
|
|
|
```bash
|
|
|
|
yq --from-file update.yq sample.yml
|
|
|
|
```
|
|
|
|
will output
|
|
|
|
```yaml
|
|
|
|
a:
|
|
|
|
b: new
|
|
|
|
```
|
|
|
|
|