【Go】字符串相关知识点

发布于:2025-03-13 ⋅ 阅读:(12) ⋅ 点赞:(0)

字符串(String)是 Go 语言中最常用的数据类型之一,广泛应用于文本处理、数据解析、网络通信等场景。Go 语言的字符串是不可变的 UTF-8 字节序列,在性能和安全性方面与其他编程语言有所不同。

源代码

package main

//字符类型 byte rune

//编码 人类语言---机器语言  映射
//ascii -- 英文字符
//unicode -- 万国码 utf8 gbk 是unicode具体实现,实现存入磁盘,它们都有不同的标志位来区分

//byte -- uint8   英文字符使用byte
//runne -- uint32  中文等其它字符使用runne

//字符串类型 string 双引号包裹
//如果在go里面使用字符串,一定要使用双引号!

import (
	"fmt"
	"strconv"
	"strings"
	"unicode/utf8"
)

func main() {
	string_1()
	string_2()
}

func string_1() {

	var c1 byte
	c1 = 97
	fmt.Println(c1, "\nsrting 将字符类型转换成文字显示:", string(c1)) //

	var c2 = '中'                   //单引号得到的是字节码,不能用单引号引起多个字符
	fmt.Println("单引号输出中的字节码编码是:", c2) //这里输出的就是中的字节码,而不是 字符
	fmt.Printf("%T\n", c2)

	//如下情况会报错《more than one character in rune literal》
	//var c3 = '中国'

	//双引号原样输出
	var str1 string
	str1 = "中" //双引号包裹字符串
	fmt.Println("双引号输出字符,而不是字符码:", str1)
	var str2 string
	str2 = "中国"
	fmt.Println(str2)

	//统计字符串的长度 -- len(s1 srting类型) -- utf8.RuneCountInString(s1 srting类型)
	var str3 string
	var str4 string
	str3 = "abc萝卜子"
	//len 统计字节数,不是字符数
	fmt.Println("str3=abc萝卜子,占用的字节数是(中文占用3字节):", len(str3))
	str4 = "...中国china"
	//utf8.RuneCountInString(s1 srting类型) 统计字符串的长度 --> 统计unicode码的个数
	count := utf8.RuneCountInString(str4)
	fmt.Println("str4=...中国china,的字符个数是:", count)

	//转义字符  --  含有特殊含义的字符
	// \t制表符  \n换行符 \" 特殊符号本身
	fmt.Println("--------------------\n\n\n转义字符:")
	var str5 string
	var str6 string
	str5 = "hello\n\"\t\\world"
	//反引号包裹的字符串——> 原样输出
	str6 = `反引号包裹的字符串——> 原样输出: hello \n\t\\\" world`
	fmt.Println(str5)
	fmt.Println(str6)

	//字符串的截取 [start:end] 按字节截取
	fmt.Println("--------------------\n\n\n")
	fmt.Println("字符串的截取 [start:end] 按字节截取")
	var str7 string
	var str8 string
	str7 = "hello world!"
	str8 = "你好世界" //反引号
	/*
		hello wor l  d
		123456789 10 11
		[) 左闭右开区间
	*/
	fmt.Println(str7[0:4])
	fmt.Println("省略开始:", str7[:4])
	fmt.Println("省略结束:", str7[4:])
	fmt.Println("中文不太支持截取操作(按字节截取,中文3字节):", str8[0:8])

	//字符串和其它数据的转换 -- strconv 库
	//将整形转成字符串
	num1 := 200
	str9 := strconv.Itoa(num1)
	fmt.Printf("将整形转成字符串: \nstr9 is %s,type is %T\n", str9, str9)

	//字符串转换成整形
	str10 := "100"                 //必须要数字的字符串才能转换,abc不能转成整形!
	num2, e := strconv.Atoi(str10) //返回两个值  不能转换e就会拿到错误信息
	if e != nil {                  //nil 为空表示 没有错误信息
		fmt.Println(e)
	} else {
		fmt.Printf("字符串转成整形: \nstr9 is %d,type is %T\n", num2, num2)
	}
	/*
		   % -- %s 字符串
				%c 转换成字符的形式显示 类似与string()
				%d 十进制
				%x 十六进制
				%% %号本身
				%T 输出类型
				%.2f保留两位小数
				%v 输出具体值
	*/

	fmt.Println("--------------------\n")
	//将格式化好的字符串赋值给另一个变量
	str11 := fmt.Sprintf("my name is %s,age is %d", "luobozi", 21)
	fmt.Println("格式化赋值:", str11)
	fmt.Println("--------------------\n")
	//字符串的遍历
	fmt.Println("字符串的遍历")
	str12 := "abcdefg"
	str13 := "hello,萝卜子"

	//按照字节遍历
	fmt.Println("按照字节遍历")
	for i := 0; i < len(str12); i++ {
		fmt.Printf("%v(%c) type: %T \n", str12[i], str12[i], str12[i])
	}

	//按照字符个数遍历
	fmt.Println("\n按照字符个数遍历")
	for _, i := range str13 { //连个值,一个下标,一个具体值,这里下标使用匿名函数接受,因为使用不到
		fmt.Println(i, string(i))
	}

}

func string_2() {
	//接收用户从键盘输入的任意字符串,统计其中英文字母、数字、其他字符的个数

	//统计输入的字符串中,出现的最多的字符和个数,最少字符和个数

	//var input string
	//fmt.Println("请输入一串字符:")
	//fmt.Scanln(&input)
	//fmt.Println(input)
	//max := 0
	//max_char := ""
	//min := utf8.RuneCountInString(input) + 1
	//min_char := ""
	//for _, str_num := range input {
	//	count := 0
	//	for _, str_num_2 := range input {
	//		if str_num_2 == str_num {
	//			count += 1
	//		}
	//	}
	//	if count > max {
	//		max = count
	//		max_char = string(str_num)
	//	}
	//	if count < min {
	//		min = count
	//		min_char = string(str_num)
	//	}
	//}
	//fmt.Println(max, max_char)
	//fmt.Println(min, min_char)

	fmt.Println("--------------------\n")
	//字符串的常用方法 -- strings 包
	//字符串的查找和替换 Contains(s1,s2 string类型) 返回bool 判断字符串s1中是不是包含s2
	//统计字符出现的次数Count(s1, s2 string类型)  计算s1中出现s2的次数
	//Idenx(s1,s2 string类型) 返回s2在s1中第一次出现的位置,若不存在就返回-1
	//Replace(s1,old,new string类型,int 类型)  将s1中前n个old子串替换成new n为-1 表示全部替换
	//Split(s1,sep string类型)根据sep将s1分割成几个部分 返回的是一个数组
	//Tolower(s1 string类型)将s1转换成小写
	//ToUpper(s1 string类型)将s1转换成大写  用在大小写不敏感的场景中
	//Trim(s1,s2 string类型) 将s1两侧的s2字符去除
	//HasPrefix(s1,s2 string类型) 判断s1是不是以s2开头
	//HasSuffix(s1,s2 string类型) 判断s1是不是以s2结尾

	fmt.Println("字符串的常用方法 -- strings 包")
	//字符串的常用方法 -- strings 包
	//字符串的查找和替换 Contains(s1,s2 string类型) 返回bool 判断字符串s1中是不是包含s2
	str_2 := "abcdeffsadfasdf"
	if strings.Contains(str_2, "ab") { //判断子串字符(substr)是否在字符串中
		fmt.Println("条件成立,子串在str_2中")
	}
	//统计字符出现的次数Count(s1, s2 string类型)  计算s1中出现s2的次数
	fmt.Println("a在str_2中出现的次数:", strings.Count(str_2, "a"))

	//Idenx(s1,s2 string类型) 返回s2在s1中第一次出现的位置,若不存在就返回-1
	en_str_2 := "1234567"
	fmt.Println("子串 1 出现在en_str_2下标:", strings.Index(en_str_2, "1"))
	fmt.Println("子串 4 出现在en_str_2下标:", strings.Index(en_str_2, "4"))

	//Replace(s1,old,new string类型,int 类型)  将s1中前n个old子串替换成new n为-1 表示全部替换
	en_str_3 := "hello,world,luobozi,world"
	fmt.Println("替换匹配到的第一个:", strings.Replace(en_str_3, "world", "HuNanChangSha", 1))
	fmt.Println("替换全部匹配成功的字符串:", strings.Replace(en_str_3, "world", "HuNanChangSha", -1))

	//Split(s1,sep string类型)根据sep将s1分割成几个部分 返回的是一个数组
	en_str_4 := "hello/world/HuNan/ChangSha/luobozi/"
	fmt.Println("en_str_4通过 / 符号分割后返回一个数组:", strings.Split(en_str_4, "/"))

	//ToLower(s1 string类型)将s1转换成小写
	//ToUpper(s1 string类型)将s1转换成大写  用在大小写不敏感的场景中
	en_str_5 := "HELLO WORLD HUNAN CHANGSHA LUOBOZI"
	en_str_6 := "from changsha hunan china"
	fmt.Println("将en_str_5转换成小写:", strings.ToLower(en_str_5))
	fmt.Println("将en_str_6转换成大写:", strings.ToUpper(en_str_6))
	//写一个大小写转换的代码
	en_str_1 := "START|asdfljklFASDASDFasdfiaASDF123aszASDQWEQ|end"
	resp := ""
	for _, v := range en_str_1 {
		if v >= 97 && v <= 122 {
			resp += string(v - 32)
		} else if v >= 65 && v <= 90 {
			resp += string(v + 32)
		} else {
			resp += string(v)
		}
	}
	fmt.Println("en_str_1字母大小写转换后:", resp)

	//Trim(s1,s2 string类型) 将s1两侧的s2字符去除  常用方式:清洗首尾的空格、清洗首尾的特殊符号
	en_str_7 := "**这是md加粗语法**"
	fmt.Println("将en_str_7的前后的 * 号清洗掉:", strings.Trim(en_str_7, "*"))

	//HasPrefix(s1,s2 string类型) 判断s1是不是以s2开头 返回bool类型
	//HasSuffix(s1,s2 string类型) 判断s1是不是以s2结尾 返回bool类型
	en_str_8 := "IP:192.168.100.254"
	fmt.Println("en_str_8 是否以IP 开头:", strings.HasPrefix(en_str_8, "IP"))
	fmt.Println("en_str_8 是否以254 结尾:", strings.HasSuffix(en_str_8, "254"))

}

输出结果如下

97 
srting 将字符类型转换成文字显示: a
单引号输出中的字节码编码是: 20013
int32
双引号输出字符,而不是字符码: 中
中国
str3=abc萝卜子,占用的字节数是(中文占用3字节): 12
str4=...中国china,的字符个数是: 10
--------------------


转义字符:
hello
"	\world
反引号包裹的字符串——> 原样输出: hello \n\t\\\" world
--------------------



字符串的截取 [start:end] 按字节截取
hell
省略开始: hell
省略结束: o world!
中文不太支持截取操作(按字节截取,中文3字节): 你好�
将整形转成字符串: 
str9 is 200,type is string
字符串转成整形: 
str9 is 100,type is int
--------------------

格式化赋值: my name is luobozi,age is 21
--------------------

字符串的遍历
按照字节遍历
97(a) type: uint8 
98(b) type: uint8 
99(c) type: uint8 
100(d) type: uint8 
101(e) type: uint8 
102(f) type: uint8 
103(g) type: uint8 

按照字符个数遍历
104 h
101 e
108 l
108 l
111 o
44 ,
33821 萝
21340 卜
23376 子
--------------------

字符串的常用方法 -- strings 包
条件成立,子串在str_2中
a在str_2中出现的次数: 3
子串 1 出现在en_str_2下标: 0
子串 4 出现在en_str_2下标: 3
替换匹配到的第一个: hello,HuNanChangSha,luobozi,world
替换全部匹配成功的字符串: hello,HuNanChangSha,luobozi,HuNanChangSha
en_str_4通过 / 符号分割后返回一个数组: [hello world HuNan ChangSha luobozi ]
将en_str_5转换成小写: hello world hunan changsha luobozi
将en_str_6转换成大写: FROM CHANGSHA HUNAN CHINA
en_str_1字母大小写转换后: start|ASDFLJKLfasdasdfASDFIAasdf123ASZasdqweq|END
将en_str_7的前后的 * 号清洗掉: 这是md加粗语法
en_str_8 是否以IP 开头: true
en_str_8 是否以254 结尾: true

进程 已完成,退出代码为 0