mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-14 20:45:36 +00:00
326 lines
4.4 KiB
Markdown
326 lines
4.4 KiB
Markdown
# Add
|
|
|
|
Add behaves differently according to the type of the LHS:
|
|
* arrays: concatenate
|
|
* number scalars: arithmetic addition
|
|
* string scalars: concatenate
|
|
* maps: shallow merge (use the multiply operator (`*`) to deeply merge)
|
|
|
|
Use `+=` as a relative append assign for things like increment. Note that `.a += .x` is equivalent to running `.a = .a + .x`.
|
|
|
|
|
|
{% hint style="warning" %}
|
|
Note that versions prior to 4.18 require the 'eval/e' command to be specified. 
|
|
|
|
`yq e <exp> <file>`
|
|
{% endhint %}
|
|
|
|
## Concatenate arrays
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
- 1
|
|
- 2
|
|
b:
|
|
- 3
|
|
- 4
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a + .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- 1
|
|
- 2
|
|
- 3
|
|
- 4
|
|
```
|
|
|
|
## Concatenate to existing array
|
|
Note that the styling of `a` is kept.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: [1,2]
|
|
b:
|
|
- 3
|
|
- 4
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a += .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: [1, 2, 3, 4]
|
|
b:
|
|
- 3
|
|
- 4
|
|
```
|
|
|
|
## Concatenate null to array
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
- 1
|
|
- 2
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a + null' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- 1
|
|
- 2
|
|
```
|
|
|
|
## Append to existing array
|
|
Note that the styling is copied from existing array elements
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: ['dog']
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a += "cat"' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: ['dog', 'cat']
|
|
```
|
|
|
|
## Add new object to array
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
- dog: woof
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a + {"cat": "meow"}' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- dog: woof
|
|
- cat: meow
|
|
```
|
|
|
|
## Relative append
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
a1:
|
|
b:
|
|
- cat
|
|
a2:
|
|
b:
|
|
- dog
|
|
a3: {}
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a[].b += ["mouse"]' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a:
|
|
a1:
|
|
b:
|
|
- cat
|
|
- mouse
|
|
a2:
|
|
b:
|
|
- dog
|
|
- mouse
|
|
a3:
|
|
b:
|
|
- mouse
|
|
```
|
|
|
|
## String concatenation
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: cat
|
|
b: meow
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a += .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: catmeow
|
|
b: meow
|
|
```
|
|
|
|
## Number addition - float
|
|
If the lhs or rhs are floats then the expression will be calculated with floats.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: 3
|
|
b: 4.9
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a = .a + .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: 7.9
|
|
b: 4.9
|
|
```
|
|
|
|
## Number addition - int
|
|
If both the lhs and rhs are ints then the expression will be calculated with ints.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: 3
|
|
b: 4
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a = .a + .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: 7
|
|
b: 4
|
|
```
|
|
|
|
## Increment numbers
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: 3
|
|
b: 5
|
|
```
|
|
then
|
|
```bash
|
|
yq '.[] += 1' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: 4
|
|
b: 6
|
|
```
|
|
|
|
## Date addition
|
|
You can add durations to dates. Assumes RFC3339 date time format, see [date-time operators](https://mikefarah.gitbook.io/yq/operators/date-time-operators) for more information.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: 2021-01-01T00:00:00Z
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a += "3h10m"' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: 2021-01-01T03:10:00Z
|
|
```
|
|
|
|
## Date addition - custom format
|
|
You can add durations to dates. See [date-time operators](https://mikefarah.gitbook.io/yq/operators/date-time-operators) for more information.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: Saturday, 15-Dec-01 at 2:59AM GMT
|
|
```
|
|
then
|
|
```bash
|
|
yq 'with_dtf("Monday, 02-Jan-06 at 3:04PM MST", .a += "3h1m")' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: Saturday, 15-Dec-01 at 6:00AM GMT
|
|
```
|
|
|
|
## Add to null
|
|
Adding to null simply returns the rhs
|
|
|
|
Running
|
|
```bash
|
|
yq --null-input 'null + "cat"'
|
|
```
|
|
will output
|
|
```yaml
|
|
cat
|
|
```
|
|
|
|
## Add maps to shallow merge
|
|
Adding objects together shallow merges them. Use `*` to deeply merge.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
thing:
|
|
name: Astuff
|
|
value: x
|
|
a1: cool
|
|
b:
|
|
thing:
|
|
name: Bstuff
|
|
legs: 3
|
|
b1: neat
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a += .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a:
|
|
thing:
|
|
name: Bstuff
|
|
legs: 3
|
|
a1: cool
|
|
b1: neat
|
|
b:
|
|
thing:
|
|
name: Bstuff
|
|
legs: 3
|
|
b1: neat
|
|
```
|
|
|
|
## Custom types: that are really strings
|
|
When custom tags are encountered, yq will try to decode the underlying type.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: !horse cat
|
|
b: !goat _meow
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a += .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: !horse cat_meow
|
|
b: !goat _meow
|
|
```
|
|
|
|
## Custom types: that are really numbers
|
|
When custom tags are encountered, yq will try to decode the underlying type.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: !horse 1.2
|
|
b: !goat 2.3
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a += .b' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a: !horse 3.5
|
|
b: !goat 2.3
|
|
```
|
|
|