Go的字符串操作
程序员文章站
2022-07-13 21:10:01
...
计算字符串的长度
Go语言中的字符串都是以UTF-8格式保存的,每个中文占三个字节,因此使用len()获取两个中文文字对应的6个字节。
如果是按照习惯上统计中文字符,使用UTF-8包中提供的RuneCountInString()函数即可
package main
import (
"fmt"
"unicode/utf8"
)
func main() {
fmt.Println("hello world length: ", len("hello world")) // 输出11
fmt.Println("你好 世界 长度(每个中文占三个字节): ", len("你好 世界")) // 输出13
fmt.Println("你好 世界 字符长度: ", utf8.RuneCountInString("你好 世界")) // 输出5
}
遍历字符串
遍历字符串ascii
此遍历方式适合遍历ASCII字符串
package main
import "fmt"
func asciiForeach(str string) {
for i := 0; i < len(str); i++ {
fmt.Printf("ascii: %c %d\n", str[i], str[i])
}
}
func main() {
asciiForeach("我是stu");
}
输出:
ascii: æ 230
ascii: 136
ascii: 145
ascii: æ 230
ascii: 152
ascii: ¯ 175
ascii: s 115
ascii: t 116
ascii: u 117
遍历有中文的字符串
package main
import "fmt"
func strForeach(str string) {
// range返回数据的索引和值
for _, s := range str {
fmt.Printf("Unicode: %c %d\n", s, s)
}
}
func main() {
strForeach("我是stu")
}
输出:
Unicode: 我 25105
Unicode: 是 26159
Unicode: s 115
Unicode: t 116
Unicode: u 117
截取字符串
使用strings.Index
package main
import (
"fmt"
"strings"
)
// 截取字符串
func subStr(start int, str string) string{
return str[start:]
}
func main() {
str := "狼来了 狼来了"
// 返回"狼"的下标
start := strings.Index(str, "狼")
// 打印
fmt.Println(start, subStr(start, str))
}
输出:
0 狼来了 狼来了
字符串转数组,并修改
- go语言的字符串同Java一样也是不可变的,天生线程安全
- 字符串需要修改的时候需要转换为[]byte数组后进行修改
- 不能直接修改为中文,因为中文占用三个字节
package main
import (
"fmt"
)
func main() {
str := "a来了 b来了"
// 修改字符串
strArr := []byte(str)
strArr[0] = 'c'
// 打印
fmt.Println(string(strArr))
}
输出:
c来了 b来了
连接字符串
package main
import (
"bytes"
"fmt"
)
func main() {
str1 := "a来了 b来了"
str2 := "c来了 d来了"
// 打印
fmt.Println(str1 + str2)
// 使用stringBuilder高效连接
var stringBuilder bytes.Buffer
stringBuilder.WriteString(str1)
stringBuilder.WriteString(str2)
fmt.Println(stringBuilder.String())
}
输出:
a来了 b来了c来了 d来了
a来了 b来了c来了 d来了
字符串格式化
fmt.Printf(格式化样式, 参数列表...)
上一篇: LInux 免key登录
下一篇: Go语言---字符串的基本操作