yq/pkg/yqlib/doc/Assign (Update).md

205 lines
2.5 KiB
Markdown
Raw Normal View History

2020-11-19 06:08:13 +00:00
2020-12-01 03:06:49 +00:00
## Create yaml file
Running
```bash
yq eval --null-input '.a.b = "cat" | .x = "frog"'
2020-12-01 03:06:49 +00:00
```
will output
```yaml
a:
b: cat
x: frog
```
2020-11-22 02:16:54 +00:00
## Update node to be the child value
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
a:
b:
g: foof
```
then
```bash
yq eval '.a |= .b' sample.yml
```
will output
```yaml
2020-11-17 23:32:30 +00:00
a:
g: foof
```
2021-07-07 09:53:33 +00:00
## Double elements in an array
Given a sample.yml file of:
```yaml
- 1
- 2
- 3
```
then
```bash
yq eval '.[] |= . * 2' sample.yml
```
will output
```yaml
- 2
- 4
- 6
```
2021-01-01 23:27:32 +00:00
## Update node from another file
Note this will also work when the second file is a scalar (string/number)
Given a sample.yml file of:
```yaml
a: apples
```
And another sample another.yml file of:
```yaml
b: bob
```
then
```bash
yq eval-all 'select(fileIndex==0).a = select(fileIndex==1) | select(fileIndex==0)' sample.yml another.yml
```
will output
```yaml
a:
b: bob
```
2020-11-22 02:16:54 +00:00
## Update node to be the sibling value
2020-11-19 06:08:13 +00:00
Given a sample.yml file of:
```yaml
a:
b: child
b: sibling
```
then
```bash
yq eval '.a = .b' sample.yml
```
will output
```yaml
a: sibling
b: sibling
```
2020-11-22 02:16:54 +00:00
## Updated multiple paths
2020-11-17 23:32:30 +00:00
Given a sample.yml file of:
```yaml
a: fieldA
b: fieldB
c: fieldC
```
then
```bash
2021-07-07 09:53:33 +00:00
yq eval '(.a, .c) = "potatoe"' sample.yml
2020-11-17 23:32:30 +00:00
```
will output
```yaml
a: potatoe
b: fieldB
c: potatoe
2020-11-17 22:44:16 +00:00
```
2020-11-22 02:16:54 +00:00
## Update string value
2020-11-19 06:08:13 +00:00
Given a sample.yml file of:
```yaml
a:
b: apple
```
then
```bash
yq eval '.a.b = "frog"' sample.yml
```
will output
```yaml
a:
b: frog
```
2020-11-22 02:16:54 +00:00
## Update string value via |=
2020-11-19 06:08:13 +00:00
Note there is no difference between `=` and `|=` when the RHS is a scalar
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
a:
b: apple
```
then
```bash
yq eval '.a.b |= "frog"' sample.yml
```
will output
```yaml
2020-11-17 23:32:30 +00:00
a:
b: frog
2020-11-17 22:44:16 +00:00
```
2021-10-27 22:15:28 +00:00
## Update deeply selected results
Note that the LHS is wrapped in brackets! This is to ensure we dont first filter out the yaml and then update the snippet.
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
a:
b: apple
c: cactus
```
then
```bash
2020-12-26 10:37:08 +00:00
yq eval '(.a[] | select(. == "apple")) = "frog"' sample.yml
2020-11-17 22:44:16 +00:00
```
will output
```yaml
2020-11-17 23:32:30 +00:00
a:
b: frog
c: cactus
2020-11-17 22:44:16 +00:00
```
2020-11-22 02:16:54 +00:00
## Update array values
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
- candy
- apple
- sandy
```
then
```bash
yq eval '(.[] | select(. == "*andy")) = "bogs"' sample.yml
2020-11-17 22:44:16 +00:00
```
will output
```yaml
2020-11-17 23:32:30 +00:00
- bogs
- apple
- bogs
2020-11-17 22:44:16 +00:00
```
2020-11-22 02:16:54 +00:00
## Update empty object
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
2020-11-22 02:16:54 +00:00
{}
2020-11-17 22:44:16 +00:00
```
then
```bash
yq eval '.a.b |= "bogs"' sample.yml
```
will output
```yaml
2020-11-22 02:16:54 +00:00
{a: {b: bogs}}
2020-11-17 22:44:16 +00:00
```
2020-11-22 02:16:54 +00:00
## Update empty object and array
2020-11-17 22:44:16 +00:00
Given a sample.yml file of:
```yaml
2020-11-22 02:16:54 +00:00
{}
2020-11-17 22:44:16 +00:00
```
then
```bash
yq eval '.a.b.[0] |= "bogs"' sample.yml
2020-11-17 22:44:16 +00:00
```
will output
```yaml
2020-11-22 02:16:54 +00:00
{a: {b: [bogs]}}
2020-11-17 22:44:16 +00:00
```