golang 小说章节排序方式
在 golang 中,可以使用自定义排序规则来对小说章节进行排序。首先,我们需要实现三个接口:
其中 less 函数是需要我们自己实现的,下面是一个示例代码,使用正则表达式来提取章节名称并进行比较:
type chapter []string func (ss chapter) len() int { return len(ss) } func (ss chapter) swap(i, j int) { ss[i], ss[j] = ss[j], ss[i] } 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 := 0; idx < min(len(ciarr), len(cjarr)); idx++ { // 按索引比较ciarr和cjarr数组的大小,ciarr[idx]小于或者大于cjarr[idx],立刻返回true或者false。 if ciarr[idx] < cjarr[idx] { return true } else if ciarr[idx] > cjarr[idx] { return false } } if len(ciarr) < len(cjarr) { // 如果数组元素完全相等(最小长度范围内),长度小的数组更小。 return true } return false }
通过实现这些接口,我们可以使用 sort.sort() 函数对章节切片进行排序:
sort.Sort(Chapter(chSlice)) // 举例chSlice为章节切片
排序后,切片中的章节将按照自定义规则排序。