strings包也是go中使用频繁的包,只要是涉及字符串的操作就要用到这个包。现在针对于这个包里常用的方法做下总结。
strings.Index strings.IndexRune strings.IndexAny strings.IndexByte 四个都是查询字符在字符串所在第一次出现位置的方法,区别只在于查找的类型,IndexRune IndexByte分别是rune类型和byte类型,在这里说明下双引号“ ”和单引号‘ ’的区别,双引号用做常用的字符串类型,单引号表示rune或byte。
例
a1:="d123456"a2:="我们都是好孩子"
a2:="我们都是好孩子"
index1 := strings.Index(a1,"2")
index2 :=strings.IndexRune(a2,'是')
相对应的,还有查找字符在被查询字符串最后一次出现位置的
LastIndex,LastIndexAny, LastIndexByte,LastIndexFunc
strings.Count 查询字符串在被查询字符串中出现的次数
例 a1:="我们都是好孩子是"
b1 := strings.Count(a1,"是")
strings.Join 将数组里面每个值用 字符进行连接生成新的字符串
例 strings.Join([]string{"a","b","c"},"-") 输出 a-b-c
string.Split 将字符串按分隔字符进行切割生成数组,与join方法正好相反
例 strings.Split("a-b-c","-")
strings.Contains 判断被查询字符串中是否包含查询字符串 底层调用的还是Index方法,只是这个返回值是bool。对应的还有ContainsAny,ContainsRune 两个方法
strings.Compare 判断两个字符串是否相等,区分大小写 (注:最简单判断字符串是否相等可以用 ==来判断)
strings.EqualFold 判断两个字符串是否相等,不区分大小写
strings.Replace 字符串替换
strings.ToUpper 将所有小写转换为大写 ToTitle跟这个功能一样区别只在于某些特殊语言文字上面不一样,不过都是英文的话就没区别
strings.ToLower 将所有大写转换为小写
strings.Trim 将字符串首尾指定字符删除 同样的TrimLeft 和TrimRight 分别是把前面和后面删除
string.TrimPrefix 这个和TrimLeft功能类似,区别在于
例子:
a1:="dwkkei@#d8e"
fmt.Println(strings.TrimLeft(a1,"dwk")) 输出 ei@#d8e
fmt.Println(strings.TrimPrefix(a1,"dwk")) 输出 kei@#d8e
看出来了吧,只要后续还有包含在要删除字符串的字符 TrimLeft就会删除,而TrimPrefix只删除需要删除的
TrimRight 和TrimSuffix 与上面讲例子一样
go的字符串方法常用的基本都在这,还有些可以自己去试试,下面分享个小技巧
go中,用len方法可以得到字符串长度但如果是中英文混合的话,那得到的个数就是中文按3个字符,英文按一个字符,比如string :=“你好abc”, len(string)得到的就是9 如何中英文都按照一个来算数量呢,go提供了utf8包来专门进行utf8字符的操作 utf8.RuneCountInString(string)就可以了得到 5
有时候我们还需要进行int和string之间的相互转换,go提供了strconv包来进行转换
string转成int:
int, err := strconv.Atoi(string)
string转成int64:
int64, err := strconv.ParseInt(string, 10, 64)
int转成string:
string := strconv.Itoa(int)
int64转成string:
string := strconv.FormatInt(int64,10)
这些有兴趣可以再看看相应的包函数,下一篇我们分析下time包