当数字存储为字符串时,这是编程中的一个问题-因为作为字符串,当按字母顺序排序时,它们将从头到尾按每个数字排列。例如,在处理带编号的文件名时,您可能会遇到此问题,这些文件名将被视为字符串,但是我们可能需要按顺序处理它们。
在下面的示例中,我们同时使用sort和strconv包对数组进行排序,并将字符串转换为比较函数中的数字。转换为整数可以为我们提供可靠的排序。
由于b站编辑器原因代码显示效果不太好,需要代码和视频的朋友可以去我的博客下载:http://www.topgoer.com/
package main
import (
"fmt"
"sort"
"strconv")func main() {
myList := []string{"1", "10", "11", "2", "3", "4", "5", "6", "7", "8", "9"}
fmt.Printf("Before: %v\n", myList)
// Pass in our list and a func to compare values
sort.Slice(myList, func(i, j int) bool {
numA, _ := strconv.Atoi(myList[i])
numB, _ := strconv.Atoi(myList[j])
return numA < numB })
fmt.Printf("After: %v\n", myList)}