Golang如何使用sort对数据排序_Golang sort排序操作实践

先按年龄升序再按姓名升序排序:使用sort.Slice定义多级比较逻辑,通过匿名函数实现自定义规则,如年龄相同时比较姓名字符串。

Go语言中,sort 包提供了对切片和自定义数据结构进行排序的高效方法。掌握它的使用方式,能帮助你在处理列表数据时更加得心应手。本文将通过实际例子讲解如何用 sort 对常见数据类型以及结构体进行排序。

对基本类型切片排序

对于整数、字符串等基本类型的切片,sort 提供了封装好的函数,使用起来非常简单。

例如:
  • 整数排序:使用 sort.Ints()
  • 浮点数排序:使用 sort.Float64s()
  • 字符串排序:使用 sort.Strings()

示例代码:

nums := []int{5, 2, 6, 3, 1, 4}
sort.Ints(nums)
fmt.Println(nums) // 输出: [1 2 3 4 5 6]

strs := []string{"banana", "apple", "cherry"}
sort.Strings(strs)
fmt.Println(strs) // 输出: [apple banana cherry]

对结构体切片排序

当需要对结构体切片排序时,可以实现 sort.Interface 接口,或者使用 sort.Slice() 函数更方便地指定比较逻辑。

方法一:实现 sort.Interface

结构体切片需实现 Len()、Less() 和 Swap() 方法。

type Person struct {
    Name string
    Age  int
}

type ByAge []Person

func (a ByAge) Len() int           { return len(a) }
func (a ByAge) Less(i, j int) bool { return a[i].Age < a[j].Age }
func (a ByAge) Swap(i, j int)      { a[i], a[j] = a[j], a[i] }

// 使用
people := []Person{
    {"Alice", 30},
    {"Bob", 25},
    {"Charlie", 35},
}
sort.Sort(ByAge(people))
fmt.Println(people) // 按年龄升序
方法二:使用 sort.Slice(推荐)

无需定义新类型,直接传入比较函数即可。

sort.Slice(people, func(i, j int) bool {
    return people[i].Age < people[j].Age
})

这种方式更简洁,适合临时排序需求。也可以按姓名排序:

sort.Slice(people, func(i, j int) bool {
    return people[i].Name < people[j].Name
})

逆序排序

如果要降序排列,只需反转比较条件。

sort.Slice(people, func(i, j int) bool {
    return people[i].Age > people[j].Age // 年龄从大到小
})

或对字符串降序:

sort.Slice(strs, func(i, j int) bool {
    return strs[i] > strs[j]
})

自定义复杂排序规则

支持多级排序。例如先按年龄升序,年龄相同时按姓名升序。

sort.Slice(people, func(i, j int) bool {
    if people[i].Age == people[j].Age {
        return people[i].Name < people[j].Name
    }
    return people[i].Age < people[j].Age
})

基本上就这些。Go 的 sort 包设计简洁,配合 sort.Slice 能快速完成大多数排序任务,不需要重复造轮子。关键在于理解比较函数的返回值控制顺序,写起来直观又高效。不复杂但容易忽略细节,比如索引边界和稳定排序特性,实际使用时注意验证结果。基本上就这些。