2022-02-01 03:47:51 +00:00
# Eval
Use `eval` to dynamically process an expression - for instance from an environment variable.
`eval` takes a single argument, and evaluates that as a `yq` expression. Any valid expression can be used, beit a path `.a.b.c | select(. == "cat")` , or an update `.a.b.c = "gogo"` .
2022-05-24 08:18:27 +00:00
Tip: This can be useful way parameterize complex scripts.
2022-02-01 03:47:51 +00:00
2022-02-06 03:39:46 +00:00
{% hint style="warning" %}
Note that versions prior to 4.18 require the 'eval/e' command to be specified. 
`yq e <exp> <file>`
{% endhint %}
2022-02-01 03:47:51 +00:00
## Dynamically evaluate a path
Given a sample.yml file of:
```yaml
pathExp: .a.b[] | select(.name == "cat")
a:
b:
- name: dog
- name: cat
```
then
```bash
yq 'eval(.pathExp)' sample.yml
```
will output
```yaml
name: cat
```
## Dynamically update a path from an environment variable
The env variable can be any valid yq expression.
Given a sample.yml file of:
```yaml
a:
b:
- name: dog
- name: cat
```
then
```bash
2022-02-01 04:11:39 +00:00
pathEnv=".a.b[0].name" valueEnv="moo" yq 'eval(strenv(pathEnv)) = strenv(valueEnv)' sample.yml
2022-02-01 03:47:51 +00:00
```
will output
```yaml
a:
b:
2022-02-01 03:58:53 +00:00
- name: moo
2022-02-01 03:47:51 +00:00
- name: cat
```