
如何用 golang 排序小说章节
在 golang 中,自定义排序规则是可行的。首先,我们需要实现 sort.interface 接口,它包含以下三个方法:
- len():返回切片的长度
- swap(i, j):交换切片中第 i 和第 j 个元素
- less(i, j):比较切片中第 i 和第 j 个元素是否满足排序规则,若满足则返回 true,否则返回 false
自定义 less(i, j) 方法
对于小说章节的排序,我们需要自定义 less(i, j) 方法来比较章节的顺序。这里提供一种基于正则表达式的比较方法:
立即学习“go语言免费学习笔记(深入)”;
func (ss chapter) less(i, j int) bool {
re := regexp.mustcompile("第(\d+)章(.+)")
ciarr := re.split(ss[i], -1)
cjarr := re.split(ss[j], -1)
for idx, gsa := range []struct {a, b string}{
{ciarr[1], cjarr[1]},
{ciarr[2], cjarr[2]},
} {
if gsa.a < gsa.b {
return true
} else if gsa.b < gsa.a {
return false
}
}
return len(ciarr) < len(cjarr)
}使用方法
实现以上接口后,即可使用 sort.sort() 函数对切片进行排序:
sort.Sort(Chapter(...))
这样一来,切片中的章节就会按照自定义的规则进行排序了。











