1 Star 0 Fork 0

Uni-Minds/utils

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
strings.go 1.67 KB
一键复制 编辑 原始数据 按行查看 历史
Liuxy 提交于 2022-10-15 14:14 . Release 1.0.0
/*
* Copyright (c) 2019-2020
* Author: LIU Xiangyu
* File: string.go
*/
package tools
import (
"encoding/json"
_ "github.com/mattn/go-runewidth"
"sort"
"strings"
)
// LineBuilder Build a string line with char given
func LineBuilder(width int, char string) string {
var bs strings.Builder
for i := 0; i < width; i++ {
bs.WriteString(char)
}
return bs.String()
}
// StringsCompress Strings to json string
func StringsCompress(strs []string) (str string, err error) {
bs, err := json.Marshal(strs)
return string(bs), err
}
// StringsDecompress Json string to strings
func StringsDecompress(str string) (strs []string, err error) {
if str == "" {
return make([]string, 0), nil
}
bs := []byte(str)
err = json.Unmarshal(bs, &strs)
return strs, err
}
func StringsDedup(slice []string) []string {
i := 0
var j int
for {
if i >= len(slice)-1 {
break
}
for j = i + 1; j < len(slice); j++ {
if slice[i] == slice[j] {
slice = append(slice[:j], slice[j+1:]...)
}
}
i++
}
return slice
}
func StringsDedupWithSort(a []string) (ret []string) {
sort.Strings(a)
aLen := len(a)
for i := 0; i < aLen; i++ {
if (i > 0 && a[i-1] == a[i]) || len(a[i]) == 0 {
continue
}
ret = append(ret, a[i])
}
return
}
// StringsExcept sort(a-b)
func StringsExcept(a []string, b []string) (ret []string) {
strx := StringsDedupWithSort(a)
stry := StringsDedupWithSort(b)
iy := 0
ix := 0
for ix < len(strx) {
if iy >= len(stry) {
ret = append(ret, strx[ix:]...)
break
}
if strx[ix] < stry[iy] {
ret = append(ret, strx[ix])
ix++
} else if strx[ix] == stry[iy] {
ix++
iy++
} else if strx[ix] > stry[iy] {
iy++
}
}
return ret
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/uni-minds/utils.git
git@gitee.com:uni-minds/utils.git
uni-minds
utils
utils
v1.0.1

搜索帮助

23e8dbc6 1850385 7e0993f3 1850385