当数字存储为字符串时,这是编程中的一个问题-因为作为字符串,当按字母顺序排序时,它们将从头到尾按每个数字排列。例如,在处理带编号的文件名时,您可能会遇到此问题,这些文件名将被视为字符串,但是我们可能需要按顺序处理它们。

在下面的示例中,我们同时使用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)}