yq/operators/contains.md

95 lines
1.2 KiB
Markdown
Raw Normal View History

2021-10-30 03:14:39 +00:00
# Contains
2021-11-03 04:00:28 +00:00
This returns `true` if the context contains the passed in parameter, and false otherwise.
2021-10-30 03:14:39 +00:00
2022-02-06 03:41:27 +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 %}
2021-11-03 04:00:28 +00:00
## Array contains array
2021-10-30 03:14:39 +00:00
Array is equal or subset of
Given a sample.yml file of:
```yaml
- foobar
- foobaz
- blarp
```
then
```bash
2022-01-28 01:45:43 +00:00
yq 'contains(["baz", "bar"])' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
true
```
## Object included in array
Given a sample.yml file of:
```yaml
"foo": 12
"bar":
- 1
- 2
- "barp": 12
"blip": 13
```
then
```bash
2022-01-28 01:45:43 +00:00
yq 'contains({"bar": [{"barp": 12}]})' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
true
```
## Object not included in array
Given a sample.yml file of:
```yaml
"foo": 12
"bar":
- 1
- 2
- "barp": 12
"blip": 13
```
then
```bash
2022-01-28 01:45:43 +00:00
yq 'contains({"foo": 12, "bar": [{"barp": 15}]})' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
false
```
## String contains substring
Given a sample.yml file of:
```yaml
foobar
```
then
```bash
2022-01-28 01:45:43 +00:00
yq 'contains("bar")' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
true
```
## String equals string
Given a sample.yml file of:
```yaml
meow
```
then
```bash
2022-01-28 01:45:43 +00:00
yq 'contains("meow")' sample.yml
2021-10-30 03:14:39 +00:00
```
will output
```yaml
true
```
2021-11-03 04:00:28 +00:00