mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-27 00:47:56 +00:00
GitBook: [#209] split docs
This commit is contained in:
parent
7ec745a2f7
commit
27268aae26
@ -53,6 +53,7 @@
|
||||
|
||||
## Usage
|
||||
|
||||
* [Split into multiple files](usage/split-into-multiple-files.md)
|
||||
* [Output format](usage/output-format.md)
|
||||
* [Working with Properties](usage/properties.md)
|
||||
* [Working with JSON](usage/convert.md)
|
||||
|
80
usage/split-into-multiple-files.md
Normal file
80
usage/split-into-multiple-files.md
Normal file
@ -0,0 +1,80 @@
|
||||
# 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 e -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 e -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 e '.[]' 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
|
||||
```
|
||||
|
Loading…
Reference in New Issue
Block a user