計算字符串的長度
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(格式化樣式, 參數列表...)