yq/usage/split-into-multiple-files.md

81 lines
1.4 KiB
Markdown
Raw Permalink Normal View History

2021-10-30 05:09:29 +00:00
# Split into multiple files
`yq` can split out the results into multiple files with the `--split-exp/s` flag. You will need to give this flag an expression (that returns a string), this will be used as the filename for each result. In this expression, you can use `$index` to represent the result index in the name, if desired.
## Split documents into files
Given a file like
```yaml
a: test_doc1
---
a: test_doc2
```
Then running:
```bash
2022-01-28 01:50:13 +00:00
yq -s '.a' myfile.yml
2021-10-30 05:09:29 +00:00
```
will result in two files:
test\_doc1.yml:
```yaml
a: test_doc1
```
test\_doc2.yml:
```yaml
---
a: test_doc2
```
TIP: if you don't want the leading document separators (`---`), then run with the `--no-doc` flag.
## Split documents into files, using index
This is like the example above, but we'll use `$index` for the filename. Note that this variable is only defined for the `--split-exp/s` flag.
```
2022-01-28 01:50:13 +00:00
yq -s '"file_" + $index' myfile.yml
2021-10-30 05:09:29 +00:00
```
This will create two files, `file_0.yml` and `file_1.yml`.
## Split single document into files
You can also split results into separate files. Notice
```yaml
- name: bob
age: 23
- name: tim
age: 17
```
Then, by splatting the array into individual results, we can split the content into several files:
```bash
2022-01-28 01:50:13 +00:00
yq '.[]' file.yml -s '"user_" + .name'
2021-10-30 05:09:29 +00:00
```
will result in two files:
user\_bob.yml:
```yaml
name: bob
age: 23
```
user\_tim.yml:
```yaml
name: tim
age: 17
```