如何用 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(...))
这样一来,切片中的章节就会按照自定义的规则进行排序了。
以上就是如何用 Golang 对小说章节进行自定义排序?的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系 yyfuon@163.com