2021-11-03 04:00:58 +00:00
# Assign (Update)
This operator is used to update node values. It can be used in either the:
### plain form: `=`
2023-03-16 02:39:36 +00:00
Which will set the LHS node values equal to the RHS node values. The RHS expression is run against the matching nodes in the pipeline.
2021-11-03 04:00:58 +00:00
### relative form: `|=`
2023-03-16 02:39:36 +00:00
This will do a similar thing to the plain form, but the RHS expression is run with _each LHS node as context_ . This is useful for updating values based on old values, e.g. increment.
2022-08-29 05:37:25 +00:00
### Flags
- `c` clobber custom tags
2021-11-03 04:00:58 +00:00
## Create yaml file
Running
```bash
2022-01-27 06:21:10 +00:00
yq --null-input '.a.b = "cat" | .x = "frog"'
2021-11-03 04:00:58 +00:00
```
will output
```yaml
a:
b: cat
x: frog
```
## Update node to be the child value
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: {g: foof}}}
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a |= .b' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
{a: {g: foof}}
2021-11-03 04:00:58 +00:00
```
## Double elements in an array
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
[1, 2, 3]
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.[] |= . * 2' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
[2, 4, 6]
2021-11-03 04:00:58 +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
2023-05-02 04:07:59 +00:00
{a: apples}
2021-11-03 04:00:58 +00:00
```
And another sample another.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{b: bob}
2021-11-03 04:00:58 +00:00
```
then
```bash
yq eval-all 'select(fileIndex==0).a = select(fileIndex==1) | select(fileIndex==0)' sample.yml another.yml
```
will output
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: bob}}
2021-11-03 04:00:58 +00:00
```
## Update node to be the sibling value
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: child}, b: sibling}
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a = .b' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
{a: sibling, b: sibling}
2021-11-03 04:00:58 +00:00
```
## Updated multiple paths
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: fieldA, b: fieldB, c: fieldC}
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-05-24 08:18:27 +00:00
yq '(.a, .c) = "potato"' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
{a: potato, b: fieldB, c: potato}
2021-11-03 04:00:58 +00:00
```
## Update string value
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: apple}}
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a.b = "frog"' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: frog}}
2021-11-03 04:00:58 +00:00
```
## Update string value via |=
Note there is no difference between `=` and `|=` when the RHS is a scalar
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: apple}}
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a.b |= "frog"' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: frog}}
2021-11-03 04:00:58 +00:00
```
## Update deeply selected results
2022-05-24 08:18:27 +00:00
Note that the LHS is wrapped in brackets! This is to ensure we don't first filter out the yaml and then update the snippet.
2021-11-03 04:00:58 +00:00
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: apple, c: cactus}}
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '(.a[] | select(. == "apple")) = "frog"' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
{a: {b: frog, c: cactus}}
2021-11-03 04:00:58 +00:00
```
## Update array values
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
[candy, apple, sandy]
2021-11-03 04:00:58 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '(.[] | select(. == "*andy")) = "bogs"' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2023-05-02 04:07:59 +00:00
[bogs, apple, bogs]
2021-11-03 04:00:58 +00:00
```
## Update empty object
Given a sample.yml file of:
```yaml
{}
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a.b |= "bogs"' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2022-04-14 22:27:22 +00:00
a:
b: bogs
2021-11-03 04:00:58 +00:00
```
2021-12-02 22:23:16 +00:00
## Update node value that has an anchor
2023-03-16 02:39:36 +00:00
Anchor will remain
2021-12-02 22:23:16 +00:00
Given a sample.yml file of:
```yaml
a: & cool cat
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a = "dog"' sample.yml
2021-12-02 22:23:16 +00:00
```
will output
```yaml
a: & cool dog
```
2021-11-03 04:00:58 +00:00
## Update empty object and array
Given a sample.yml file of:
```yaml
{}
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a.b.[0] |= "bogs"' sample.yml
2021-11-03 04:00:58 +00:00
```
will output
```yaml
2022-04-14 22:27:22 +00:00
a:
b:
- bogs
2021-11-03 04:00:58 +00:00
```
2022-08-29 05:37:25 +00:00
## Custom types are maintained by default
Given a sample.yml file of:
```yaml
a: !cat meow
b: !dog woof
```
then
```bash
yq '.a = .b' sample.yml
```
will output
```yaml
a: !cat woof
b: !dog woof
```
2023-03-16 02:39:36 +00:00
## Custom types: clobber
2022-08-29 05:37:25 +00:00
Use the `c` option to clobber custom tags
Given a sample.yml file of:
```yaml
a: !cat meow
b: !dog woof
```
then
```bash
yq '.a =c .b' sample.yml
```
will output
```yaml
a: !dog woof
b: !dog woof
```