yq/usage/formatting-expressions.md

101 lines
1.8 KiB
Markdown
Raw Permalink Normal View History

2024-02-09 03:54:36 +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
2024-03-04 23:14:15 +00:00
Note that you can execute the file directly - but make sure you make the expression file executable.
2024-02-09 03:54:36 +00:00
Given a sample.yaml file of:
```yaml
a:
b: old
```
And an 'update.yq' expression file of:
```bash
2024-03-04 23:14:15 +00:00
#! yq
2024-02-09 03:54:36 +00:00
# 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
2024-03-04 23:14:15 +00:00
./update.yq sample.yaml
2024-02-09 03:54:36 +00:00
```
will output
```yaml
a:
b: new
c: frog
```
2024-03-04 23:14:15 +00:00
## Flags in expression files
You can specify flags on the shebang line, this only works when executing the file directly.
Given a sample.yaml file of:
```yaml
a:
b: old
```
And an 'update.yq' expression file of:
```bash
#! yq -oj
# 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
./update.yq sample.yaml
```
will output
```yaml
{
"a": {
"b": "new",
"c": "frog"
}
}
```
2024-02-09 03:54:36 +00:00
## Commenting out yq expressions
2024-03-04 23:14:15 +00:00
Note that `c` is no longer set to 'frog'. In this example we're calling yq directly and passing the expression file into `--from-file`, this is no different from executing the expression file directly.
2024-02-09 03:54:36 +00:00
Given a sample.yaml file of:
```yaml
a:
b: old
```
And an 'update.yq' expression file of:
```bash
2024-03-04 23:14:15 +00:00
#! yq
2024-02-09 03:54:36 +00:00
# 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
```