我只是有一个问题,我有一系列的结构,例如
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) }
假设您要按排序Axis。你是怎样做的?
Axis
(注意:我已经看过http://golang.org/pkg/sort/,并且似乎可以正常工作,但是为了通过一个非常简单的键进行简单排序,我必须添加大约20行。我在这里有python背景一样简单sorted(planets,key=lambda n: n.Axis)-Go中有类似的东西吗?
sorted(planets,key=lambda n: n.Axis)
更新: 此答案与的旧版本有关go。对于Go1.8及更高版本,请参见下面的AndreKR答案。
go
如果您想要的内容比标准库sort包少一些,可以使用第三方github.com/bradfitz/slice包。它使用一些技巧来生成对切片进行排序所需的Len和Swap方法,因此您只需要提供一个Less方法即可。
sort
github.com/bradfitz/slice
Len
Swap
Less
使用此软件包,您可以使用以下命令执行排序:
slice.Sort(planets[:], func(i, j int) bool { return planets[i].Axis < planets[j].Axis })
该planets[:]零件是产生覆盖阵列的切片所必需的。如果您制作planets切片而不是数组,则可以跳过该部分。
planets[:]
planets