mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-15 04:55:36 +00:00
170 lines
2.1 KiB
Markdown
170 lines
2.1 KiB
Markdown
# Sort
|
|
|
|
Sorts an array. Use `sort` to sort an array as is, or `sort_by(exp)` to sort by a particular expression (e.g. subfield).
|
|
|
|
To sort by descending order, pipe the results through the `reverse` operator after sorting.
|
|
|
|
Note that at this stage, `yq` only sorts scalar fields.
|
|
|
|
|
|
{% hint style="warning" %}
|
|
Note that versions prior to 4.18 require the 'eval/e' command to be specified. 
|
|
|
|
`yq e <exp> <file>`
|
|
{% endhint %}
|
|
|
|
## Sort by string field
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- a: banana
|
|
- a: cat
|
|
- a: apple
|
|
```
|
|
then
|
|
```bash
|
|
yq 'sort_by(.a)' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- a: apple
|
|
- a: banana
|
|
- a: cat
|
|
```
|
|
|
|
## Sort descending by string field
|
|
Use sort with reverse to sort in descending order.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- a: banana
|
|
- a: cat
|
|
- a: apple
|
|
```
|
|
then
|
|
```bash
|
|
yq 'sort_by(.a) | reverse' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- a: cat
|
|
- a: banana
|
|
- a: apple
|
|
```
|
|
|
|
## Sort array in place
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
cool:
|
|
- a: banana
|
|
- a: cat
|
|
- a: apple
|
|
```
|
|
then
|
|
```bash
|
|
yq '.cool |= sort_by(.a)' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
cool:
|
|
- a: apple
|
|
- a: banana
|
|
- a: cat
|
|
```
|
|
|
|
## Sort array of objects by key
|
|
Note that you can give sort_by complex expressions, not just paths
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
cool:
|
|
- b: banana
|
|
- a: banana
|
|
- c: banana
|
|
```
|
|
then
|
|
```bash
|
|
yq '.cool |= sort_by(keys | .[0])' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
cool:
|
|
- a: banana
|
|
- b: banana
|
|
- c: banana
|
|
```
|
|
|
|
## Sort is stable
|
|
Note the order of the elements in unchanged when equal in sorting.
|
|
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- a: banana
|
|
b: 1
|
|
- a: banana
|
|
b: 2
|
|
- a: banana
|
|
b: 3
|
|
- a: banana
|
|
b: 4
|
|
```
|
|
then
|
|
```bash
|
|
yq 'sort_by(.a)' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- a: banana
|
|
b: 1
|
|
- a: banana
|
|
b: 2
|
|
- a: banana
|
|
b: 3
|
|
- a: banana
|
|
b: 4
|
|
```
|
|
|
|
## Sort by numeric field
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- a: 10
|
|
- a: 100
|
|
- a: 1
|
|
```
|
|
then
|
|
```bash
|
|
yq 'sort_by(.a)' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- a: 1
|
|
- a: 10
|
|
- a: 100
|
|
```
|
|
|
|
## Sort, nulls come first
|
|
Given a sample.yml file of:
|
|
```yaml
|
|
- 8
|
|
- 3
|
|
- null
|
|
- 6
|
|
- true
|
|
- false
|
|
- cat
|
|
```
|
|
then
|
|
```bash
|
|
yq 'sort' sample.yml
|
|
```
|
|
will output
|
|
```yaml
|
|
- null
|
|
- false
|
|
- true
|
|
- 3
|
|
- 6
|
|
- 8
|
|
- cat
|
|
```
|
|
|