mirror of
https://github.com/mikefarah/yq.git
synced 2024-11-13 22:38:04 +00:00
121 lines
1.3 KiB
Markdown
121 lines
1.3 KiB
Markdown
# Keys
|
|
|
|
Use the `keys` operator to return map keys or array indices.
|
|
|
|
{% hint style="warning" %}
|
|
Note that versions prior to 4.18 require the 'eval/e' command to be specified. 
|
|
|
|
`yq e <exp> <file>`
|
|
{% endhint %}
|
|
|
|
## Map keys
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
dog: woof
|
|
cat: meow
|
|
```
|
|
then
|
|
```bash
|
|
yq 'keys' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- dog
|
|
- cat
|
|
```
|
|
|
|
## Array keys
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- apple
|
|
- banana
|
|
```
|
|
then
|
|
```bash
|
|
yq 'keys' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- 0
|
|
- 1
|
|
```
|
|
|
|
## Retrieve array key
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- 1
|
|
- 2
|
|
- 3
|
|
```
|
|
then
|
|
```bash
|
|
yq '.[1] | key' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
1
|
|
```
|
|
|
|
## Retrieve map key
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a: thing
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a | key' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a
|
|
```
|
|
|
|
## No key
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
{}
|
|
```
|
|
then
|
|
```bash
|
|
yq 'key' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
```
|
|
|
|
## Update map key
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
x: 3
|
|
y: 4
|
|
```
|
|
then
|
|
```bash
|
|
yq '(.a.x | key) = "meow"' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
a:
|
|
meow: 3
|
|
y: 4
|
|
```
|
|
|
|
## Get comment from map key
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
a:
|
|
# comment on key
|
|
x: 3
|
|
y: 4
|
|
```
|
|
then
|
|
```bash
|
|
yq '.a.x | key | headComment' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
comment on key
|
|
```
|
|
|