go strings包分析

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包

你可能感兴趣的:(go strings包分析)