Go语言中的字符rune类型和索引访问、range循环迭代及常用字符串函数列表了解

一、Go语言中的字符rune类型、索引访问、range循环迭代

1. 字符rune类型

    Go语言的字符串是使用UTF-8编码的,UTF-8是Unicode的实现方式之一,因此可以直接在代码中使用中文,而不像python那样别扭。给我们国人开发带来很好的便利。Go语言中的原生字符串需要使用双引号("")或反引号(``)定义。单引号不能用来表示字符串,否则会报错:

invalid character literal (more than one character) cannot use '\u0000' (type rune) as type string in field value。

    在GO语言中双引号:"", 用于单行字符串。如果需要用于多行字符串,需要使用反引号:``,此时反引号中的内部会原样解析。

2. rune类型字符访问

    GO有点像python和lua, GO对字符串的访问也可以支持[]索引式访问,只能访问到字符串中的字符,但不可以修改。如下示例:

#按索引输出字串中的字符
func main() {
	strs := "abcd"
	fmt.Print(strs[0])
	fmt.Println(string(strs[0]))
	fmt.Print(strs[2])
	fmt.Println(string(strs[2]))
}
#输出内容
[C:/Go/GOPATH/src/hello]
97a
99c

    需要注意的是golang的字符称为rune(int32),等价于C中的char,如上例中直接输出strs[0]只会输出字符串的ASCII码整数值,字符串可直接与整数转换,rune实际就是整型,必需先将其转换为string才能打印出来,否则打印出来的是一个整数。如下示例:

#rune示例
func main() {
	var char rune = 'k'
	var value int = 110
	toint := int(char)
	tochar := rune(value)
	fmt.Println(toint)
	fmt.Println(tochar)
	fmt.Println(string(tochar))
}
#输出结果
[C:/Go/GOPATH/src/hello]
107
110
n

    GO语言中使用len()函数计算字符串占用的字节数,utf-8是变长字符集,英文标点占用1个字节,中文占用3个字节。go语言中的字符串实际上是类型为byte的只读切片。或者说一个字符串就是一堆字节。

    这意味着,当我们将字符存储在字符串中时,实际存储的是这个字符的字节。一个字符串包含了任意个byte,它并不限定Unicode,UTF-8或者任何其他预定义的编码。go语言中的源码定义为utf-8文本,没有其他的表示。

3. rune类型字符range循环迭代

    对字符串的遍历提供了一种特殊处理,那就是字符串上使用for…range循环。range循环迭代时,就会解码一个utf-8编码的rune。如下示例:

#字符串的Unicode遍历
func showReflect() {
	tips := "武汉加油!go!"
	fmt.Println(len(tips))
	for _, char := range []rune(tips) {
		fmt.Println(string(char))
	}
}
#打印结果
[C:/Go/GOPATH/src/hello]
18
'武''汉''加''油''!''g''o''!'

二、GO语言中的常用字符串函数列表了解

字符串比较,比较机制是字符的对称比较。
strings.Compare(a, b string) int
0表示a == b ;-1表示a < b ;1表示a > b

检测字符串 substr 是否在 s 中。
strings.Contains(s, substr string) bool

检测字符串chars的中任意字符是否出现在 s 中。
strings.ContainsAny(s, chars string) bool

检测 rune字符是否出现在 s 中。
strings.ContainsRune(s string, r rune) bool

统计字符串s中非重叠substr的数量。若统计空字符串"",会返回 s 的长度加1。
strings.Count(s, substr string) int

检测字符串 s 和 t 在忽略大小写的情况下是否相等。
strings.EqualFold(s, t string) bool

返回使用空格分割的字符串 s,结果为切片。
strings.Fields(s string) []string

使用函数确定分隔符,来分割字符串 s。结果是切片。
strings.FieldsFunc(s string, f func(rune) bool) []string

检测字符串 s 是否以字符串 prefix 作为前缀。
strings.HasPrefix(s, prefix string) bool

检测字符串 s 是否以字符串 suffix 作为后缀。
strings.HasSuffix(s, suffix string) bool

返回字符串 substr 在字符串 s 中第一次出现的索引位置,若没有出现,返回-1。
strings.Index(s, substr string) int

返回字符串 chars 中的任意字符在字符串 s 中第一次出现的索引位置,若没有出现,返回-1。
strings.IndexAny(s, chars string) int

返回byte字符 c 在字符串 s 中第一次出现的索引位置,若没有出现,返回-1。
strings.IndexByte(s string, c byte) int

返回字符串 s 中第一次满足函数 f 的rune字符的索引位置,若没有出现,返回-1。
strings.IndexFunc(s string, f func(rune) bool) int

返回run字符 r 在字符串 s 中第一次出现的索引位置,若没有出现,返回-1。
strings.IndexRune(s string, r rune) int

使用分隔符 sep 连接字符串切片 a。
strings.Join(a []string, sep string) string

返回字符串 substr 在字符串 s 中最后一次出现的索引位置,若没有出现,返回-1。
strings.LastIndex(s, substr string) int

返回字符串 chars 中的任意字符在字符串 s 中最后一次出现的索引位置,若没有出现,返回-1。
strings.LastIndexAny(s, chars string) int

返回byte字符 c 在字符串 s 中最后一次出现的索引位置,若没有出现,返回-1。
strings.LastIndexByte(s string, c byte) int

返回字符串 s 中字后一次满足函数 f 的rune字符的索引位置,若没有出现,返回-1。
strings.LastIndexFunc(s string, f func(rune) bool) int

返回字符串 s 中的每个字符经过映射函数 mapping 处理之后的字符串。
strings.Map(mapping func(rune) rune, s string) string

返回将字符串 s 重复 count 的字符串。
strings.Repeat(s string, count int) string

在字符串 s 中使用字符串 new 替换字符串 old,使用 n 限定替换次数,n设置为负数表示没有限制。返回替换结果。
strings.Replace(s, old, new string, n int) string

使用分隔符 sep 分割字符串 s,返回字符串切片
strings.Split(s, sep string) []string

在分隔符 sep 后分割字符串 s,返回字符串切片
strings.SplitAfter(s, sep string) []string

在分隔符 sep 后分割字符串 s,使用 n 限定分割的元素数量,n<0全部子字符串,n>0最后一个子字符串包含余下内容,n==0返回nil。返回子字符串切片。
strings.SplitAfterN(s, sep string, n int) []string

在分隔符 sep 分割字符串 s,使用 n 限定分割的元素数量,n<0全部子字符串,n>0最后一个子字符串包含余下内容,n==0返回nil。返回子字符串切片。
strings.SplitN(s, sep string, n int) []string

返回Title化的字符串。
strings.Title(s string) string

转换字符串 s 到小写。
strings.ToLower(s string) string

使用特定的规则转换字符串 s 到小写。
strings.ToLowerSpecial(c unicode.SpecialCase, s string) string

返回全部字符都Title化的字符串。
strings.ToTitle(s string) string

使用特定的规则将全部字符都Title化。
strings.ToTitleSpecial(c unicode.SpecialCase, s string) string

将字符串 s 中所有字符转换为大写。
strings.ToTitleSpecial(unicode.TurkishCase, "dünyanın ilk borsa yapısı Aizonai kabul edilir")

使用特定的规则将字符串 s 中所有字符转换为大写。
strings.ToUpperSpecial(c unicode.SpecialCase, s string) string

截取字符串 s 两端包裹的特定字符集 cutset。
strings.Trim(s string, cutset string) string

截取字符串 s 两端满足函数 f 的字符。
strings.TrimFunc(s string, f func(rune) bool) string

截取字符串 s 左边包裹的特定字符集 cutset。
strings.TrimLeft(s string, cutset string) string

截取字符串 s 左边满足函数 f 的字符。
strings.TrimLeftFunc(s string, f func(rune) bool) string

截取字符串 s 的前缀 prefix。
strings.TrimPrefix(s, prefix string) string

截取字符串 s 右边包裹的特定字符集 cutset。
strings.TrimRight(s string, cutset string) string

截取字符串 s 右边满足函数 f 的字符。
strings.TrimRightFunc(s string, f func(rune) bool) string

截取字符串 s 两端的空白字符。
strings.TrimSpace(s string) string

截取字符串 s 的后缀 suffix。
strings.TrimSuffix(s, suffix string) string

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

林戈的IT生涯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值