mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-13 20:15:57 +00:00
Adding recipes
This commit is contained in:
parent
e5564c18fe
commit
cda69bff5e
@ -45,6 +45,11 @@ yq -i '
|
|||||||
' file.yaml
|
' file.yaml
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Find and update an item in an array:
|
||||||
|
```bash
|
||||||
|
yq '(.[] | select(.name == "foo") | .address) = "12 cat st"'
|
||||||
|
```
|
||||||
|
|
||||||
Convert JSON to YAML
|
Convert JSON to YAML
|
||||||
```bash
|
```bash
|
||||||
yq -Poy sample.json
|
yq -Poy sample.json
|
||||||
|
52
pkg/yqlib/doc/usage/recipes.md
Normal file
52
pkg/yqlib/doc/usage/recipes.md
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
|
||||||
|
## Find items in an array
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
- name: Foo
|
||||||
|
numBuckets: 0
|
||||||
|
- name: Bar
|
||||||
|
numBuckets: 0
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq '.[] | select(.name == "Foo")' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
name: Foo
|
||||||
|
numBuckets: 0
|
||||||
|
```
|
||||||
|
|
||||||
|
### Explanation:
|
||||||
|
- `.[]` splats the array, and puts all the items in the context.
|
||||||
|
- These items are then piped (`|`) into `select(.name == "Foo")` which will select all the nodes that have a name property set to 'Foo'.
|
||||||
|
- See the [select](https://mikefarah.gitbook.io/yq/operators/select) operator for more information.
|
||||||
|
|
||||||
|
## Find and update items in an array
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
- name: Foo
|
||||||
|
numBuckets: 0
|
||||||
|
- name: Bar
|
||||||
|
numBuckets: 0
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq '(.[] | select(.name == "Foo") | .numBuckets) |= . + 1' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
- name: Foo
|
||||||
|
numBuckets: 1
|
||||||
|
- name: Bar
|
||||||
|
numBuckets: 0
|
||||||
|
```
|
||||||
|
|
||||||
|
### Explanation:
|
||||||
|
- Following from the example above`.[]` splats the array, selects filters the items.
|
||||||
|
- We then pipe (`|`) that into `.numBuckets`, which will select that field from all the matching items
|
||||||
|
- Splat, select and the field are all in brackets, that whole expression is passed to the `|=` operator as the left hand side expression, with `. + 1` as the right hand side expression.
|
||||||
|
- `|=` is the operator that updates fields relative to their own value, which is referenced as dot (`.`).
|
||||||
|
- The expression `. + 1` increments the numBuckets counter.
|
||||||
|
- See the [assign](https://mikefarah.gitbook.io/yq/operators/assign-update) and [add](https://mikefarah.gitbook.io/yq/operators/add) operators for more information.
|
||||||
|
|
@ -20,6 +20,7 @@ import (
|
|||||||
type expressionScenario struct {
|
type expressionScenario struct {
|
||||||
description string
|
description string
|
||||||
subdescription string
|
subdescription string
|
||||||
|
explanation []string
|
||||||
environmentVariables map[string]string
|
environmentVariables map[string]string
|
||||||
document string
|
document string
|
||||||
document2 string
|
document2 string
|
||||||
@ -256,6 +257,14 @@ func documentOperatorScenario(t *testing.T, w *bufio.Writer, i interface{}) {
|
|||||||
writeOrPanic(w, "will output\n")
|
writeOrPanic(w, "will output\n")
|
||||||
|
|
||||||
documentOutput(t, w, s, formattedDoc, formattedDoc2)
|
documentOutput(t, w, s, formattedDoc, formattedDoc2)
|
||||||
|
|
||||||
|
if len(s.explanation) > 0 {
|
||||||
|
writeOrPanic(w, "### Explanation:\n")
|
||||||
|
for _, text := range s.explanation {
|
||||||
|
writeOrPanic(w, fmt.Sprintf("- %v\n", text))
|
||||||
|
}
|
||||||
|
writeOrPanic(w, "\n")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func documentInput(w *bufio.Writer, s expressionScenario) (string, string) {
|
func documentInput(w *bufio.Writer, s expressionScenario) (string, string) {
|
||||||
|
48
pkg/yqlib/recipes_test.go
Normal file
48
pkg/yqlib/recipes_test.go
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
package yqlib
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
var recipes = []expressionScenario{
|
||||||
|
{
|
||||||
|
description: "Find items in an array",
|
||||||
|
explanation: []string{
|
||||||
|
"`.[]` splats the array, and puts all the items in the context.",
|
||||||
|
"These items are then piped (`|`) into `select(.name == \"Foo\")` which will select all the nodes that have a name property set to 'Foo'.",
|
||||||
|
"See the [select](https://mikefarah.gitbook.io/yq/operators/select) operator for more information.",
|
||||||
|
},
|
||||||
|
document: `[{name: Foo, numBuckets: 0}, {name: Bar, numBuckets: 0}]`,
|
||||||
|
expression: `.[] | select(.name == "Foo")`,
|
||||||
|
expected: []string{
|
||||||
|
"D0, P[0], (!!map)::{name: Foo, numBuckets: 0}\n",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
description: "Find and update items in an array",
|
||||||
|
document: `[{name: Foo, numBuckets: 0}, {name: Bar, numBuckets: 0}]`,
|
||||||
|
expression: `(.[] | select(.name == "Foo") | .numBuckets) |= . + 1`,
|
||||||
|
explanation: []string{
|
||||||
|
"Following from the example above`.[]` splats the array, selects filters the items.",
|
||||||
|
"We then pipe (`|`) that into `.numBuckets`, which will select that field from all the matching items",
|
||||||
|
"Splat, select and the field are all in brackets, that whole expression is passed to the `|=` operator as the left hand side expression, with `. + 1` as the right hand side expression.",
|
||||||
|
"`|=` is the operator that updates fields relative to their own value, which is referenced as dot (`.`).",
|
||||||
|
"The expression `. + 1` increments the numBuckets counter.",
|
||||||
|
"See the [assign](https://mikefarah.gitbook.io/yq/operators/assign-update) and [add](https://mikefarah.gitbook.io/yq/operators/add) operators for more information.",
|
||||||
|
},
|
||||||
|
expected: []string{
|
||||||
|
"D0, P[], (doc)::[{name: Foo, numBuckets: 1}, {name: Bar, numBuckets: 0}]\n",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRecipes(t *testing.T) {
|
||||||
|
for _, tt := range recipes {
|
||||||
|
testScenario(t, &tt)
|
||||||
|
}
|
||||||
|
genericScenarios := make([]interface{}, len(recipes))
|
||||||
|
for i, s := range recipes {
|
||||||
|
genericScenarios[i] = s
|
||||||
|
}
|
||||||
|
documentScenarios(t, "usage", "recipes", genericScenarios, documentOperatorScenario)
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user