字符,字节
// 字符串
s := "hello 皇甫村"
// 单独的字母,汉字,符号表示一个字符
c1 := 'h'
c2 := '皇'
// 字节。一个字节=8bit(8个二进制位)
// 一个'A' =1一个字节
// 一个utf8编码的汉字 '砂' = 一般占用3个字节
1kb = 1024字节
字符串
package main
import (
"fmt"
"strings"
)
// 字符串相关操作
var s3 = "C:\\Windows\\SoftwareDistribution\\Download"
func main() {
// 字符串长度
fmt.Println(len(s3))
// 字符串拼接
name := "理想"
world := "dsb"
fmt.Println(name + world) // 直接打印到终端
ss := fmt.Sprintf("%s%s", name, world) // 直接返回了,需要一个变量来接收
fmt.Println(ss)
// 字符串分割
ret := strings.Split(s3, "\\") // 需要用到strings这个包
fmt.Println(ret)
// 拼接
joins := strings.Join(ret, "+")
fmt.Println(joins)
// 包含
fmt.Println(strings.Contains(ss, "理性"))
results := strings.Contains(ss, "理想")
fmt.Println(results)
// 前缀和后缀,也就是以什么开头,以什么结尾,在python中相当于 startswith,endswith
fmt.Println("前缀和后缀,也就是以什么开头,以什么结尾,在python中相当于 startswith,endswith")
fmt.Println(strings.HasPrefix(ss, "理想"))
rest := strings.HasPrefix(ss, "理想")
fmt.Println(rest)
fmt.Println(strings.HasSuffix(ss, "理想"))
rest2 := strings.HasSuffix(ss, "理想")
fmt.Println(rest2)
// 判断出现的位置,返回索引值,索引也是从0开始的,跟python没差
// Index 返回子串 sep 在字符串 s 中第一次出现的位置
// 如果找不到,则返回 -1,如果 sep 为空,则返回 0。
s4 := "abcded"
ind := strings.Index(s4, "c") // 不能用单引号,cannot use 'c' (type rune) as type string in argument to strings.Index
fmt.Println(ind) //2
// LastIndex 返回子串 sep 在字符串 s 中最后一次出现的位置
// 如果找不到,则返回 -1,如果 sep 为空,则返回字符串的长度
// 使用朴素字符串比较算法实现
lastind := strings.LastIndex(s4, "c")
fmt.Println(lastind) //2
}
有疑问加站长微信联系(非本文作者)