yq/operators/load.md

95 lines
1.7 KiB
Markdown
Raw Normal View History

2021-11-24 00:15:42 +00:00
# Load
The `load`/`strload` operator allows you to load in content from another file referenced in your yaml document.
Note that you can use string operators like `+` and `sub` to modify the value in the yaml file to a path that exists in your system.
Use `strload` to load text based content as a string block, and `load` to interpret the file as yaml.
Lets say there is a file `../../examples/thing.yml`:
```yaml
a: apple is included
b: cool
```
## Simple example
Given a sample.yml file of:
```yaml
myFile: ../../examples/thing.yml
```
then
```bash
2022-01-28 01:45:43 +00:00
yq 'load(.myFile)' sample.yml
2021-11-24 00:15:42 +00:00
```
will output
```yaml
a: apple is included
b: cool.
```
## Replace node with referenced file
Note that you can modify the filename in the load operator if needed.
Given a sample.yml file of:
```yaml
something:
file: thing.yml
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '.something |= load("../../examples/" + .file)' sample.yml
2021-11-24 00:15:42 +00:00
```
will output
```yaml
something:
a: apple is included
b: cool.
```
## Replace _all_ nodes with referenced file
Recursively match all the nodes (`..`) and then filter the ones that have a 'file' attribute.
Given a sample.yml file of:
```yaml
something:
file: thing.yml
over:
here:
- file: thing.yml
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '(.. | select(has("file"))) |= load("../../examples/" + .file)' sample.yml
2021-11-24 00:15:42 +00:00
```
will output
```yaml
something:
a: apple is included
b: cool.
over:
here:
- a: apple is included
b: cool.
```
## Replace node with referenced file as string
This will work for any text based file
Given a sample.yml file of:
```yaml
something:
file: thing.yml
```
then
```bash
2022-01-28 01:45:43 +00:00
yq '.something |= strload("../../examples/" + .file)' sample.yml
2021-11-24 00:15:42 +00:00
```
will output
```yaml
something: |-
a: apple is included
b: cool.
```