snippetgoCritical
What is the shortest way to simply sort an array of structs by (arbitrary) field names?
Viewed 0 times
arraysortfieldarbitrarysimplystructstheshortestwaywhat
Problem
I just had a problem where I had an array of structs, e.g.
Lets say you want to sort it by
(Note: I have seen http://golang.org/pkg/sort/ and it seems to work, but I have to add about 20 lines just for simple sorting by a very simple key. I have a python background where it is as simple as
package main
import "log"
type Planet struct {
Name string `json:"name"`
Aphelion float64 `json:"aphelion"` // in million km
Perihelion float64 `json:"perihelion"` // in million km
Axis int64 `json:"Axis"` // in km
Radius float64 `json:"radius"`
}
func main() {
var mars = new(Planet)
mars.Name = "Mars"
mars.Aphelion = 249.2
mars.Perihelion = 206.7
mars.Axis = 227939100
mars.Radius = 3389.5
var earth = new(Planet)
earth.Name = "Earth"
earth.Aphelion = 151.930
earth.Perihelion = 147.095
earth.Axis = 149598261
earth.Radius = 6371.0
var venus = new(Planet)
venus.Name = "Venus"
venus.Aphelion = 108.939
venus.Perihelion = 107.477
venus.Axis = 108208000
venus.Radius = 6051.8
planets := [...]Planet{*mars, *venus, *earth}
log.Println(planets)
}Lets say you want to sort it by
Axis. How do you do that?(Note: I have seen http://golang.org/pkg/sort/ and it seems to work, but I have to add about 20 lines just for simple sorting by a very simple key. I have a python background where it is as simple as
sorted(planets, key=lambda n: n.Axis) - is there something similar simple in Go?)Solution
UPDATE: This answer relates to older versions of
If you want something a bit less verbose than the standard library
With this package, you can perform the sort with:
The
go. For Go 1.8 and newer, see the AndreKR's answer above.If you want something a bit less verbose than the standard library
sort package, you could use the third party github.com/bradfitz/slice package. It uses some tricks to generate the Len and Swap methods needed to sort your slice, so you only need to provide a Less method.With this package, you can perform the sort with:
slice.Sort(planets[:], func(i, j int) bool {
return planets[i].Axis < planets[j].Axis
})The
planets[:] part is necessary to produce a slice covering your array. If you make planets a slice instead of an array you could skip that part.Code Snippets
slice.Sort(planets[:], func(i, j int) bool {
return planets[i].Axis < planets[j].Axis
})Context
Stack Overflow Q#28999735, score: 101
Revisions (0)
No revisions yet.