mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-14 20:45:36 +00:00
81 lines
1.4 KiB
Markdown
81 lines
1.4 KiB
Markdown
# 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
|
|
yq -s '.a' myfile.yml
|
|
```
|
|
|
|
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.
|
|
|
|
```
|
|
yq -s '"file_" + $index' myfile.yml
|
|
```
|
|
|
|
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
|
|
yq '.[]' file.yml -s '"user_" + .name'
|
|
```
|
|
|
|
will result in two files:
|
|
|
|
user\_bob.yml:
|
|
|
|
```yaml
|
|
name: bob
|
|
age: 23
|
|
```
|
|
|
|
user\_tim.yml:
|
|
|
|
```yaml
|
|
name: tim
|
|
age: 17
|
|
```
|
|
|