Go – Sort Slice of Strings
To sort a slice of strings in Go programming, use sort
package. sort
package offers sorting for builtin datatypes and user defined datatypes, through which we can sort a slice of strings.
The sorting or strings happen lexicographically. Meaning a
is less than b
, b
is less than c
, and so on.
The syntax to sort a slice of strings strSlice
using sort
package is
sort.Strings(strSlice)
The sorting happens in-place. Therefore original slice of strings is modified.
By default, the sorting happens in ascending order. To sort in decreasing order, we may use sort.Reverse
function.
Note that we have to import sort
package prior to using sort.Strings()
function.
Examples
In the following example, we will take a slice of strings, and sort them in ascending order using sort.Strings().
example.go
package main
import (
"fmt"
"sort"
)
func main() {
strSlice := []string{"e", "c", "d", "a", "b"}
fmt.Println("Before sorting :", strSlice)
sort.Strings(strSlice)
fmt.Println("After sorting :", strSlice)
}
Output
Before sorting : [e c d a b]
After sorting : [a b c d e]
Now, we shall sort this slice of strings in decreasing order, using sort.Reverse
function.
example.go
package main
import (
"fmt"
"sort"
)
func main() {
strSlice := []string{"e", "c", "d", "a", "b"}
fmt.Println("Before sorting :", strSlice)
sort.Sort(sort.Reverse(sort.StringSlice(strSlice)))
fmt.Println("After sorting :", strSlice)
}
Output
Before sorting : [e c d a b]
After sorting : [e d c b a]
Conclusion
In this Go Tutorial, we learned how to sort a Slice of Strings in Go programming language using sort package, with the help of example programs.