Go 语言字符串常见操作
@
1. 字节数组
字节与字符的区别
字节(Byte) 是计量单位,表示数据量多少,是计算机信息技术用于计量存储容量的一种计量单位,通常情况下一字节等于八位
字符(Character) 是计算机中使用的字母、数字、字和符号,比如'A'、'B'、'$'、'&'等
一般在英文状态下一个字母或字符占用一个字节,一个汉字用两个字节表示
通俗点来说,人的语言就是字符,而字节是机器的语言
示例
package main
import "fmt"
func main() {
var (
str1 = "hello"
str2 = "world"
)
str3 := str1 + " " + str2
//字符串转换成字节数组
tmp := []byte(str3)
fmt.Printf("数据: %s,长度: %d,数据类型: %T\n", str3, len(str3), str3)
fmt.Println("字节数组:", tmp)
fmt.Printf("数据: %s,长度: %d,数据类型: %T\n", tmp, len(tmp), tmp)
//字节数组转字符串
fmt.Println("字节数组转字符串:", string(tmp))
//反转函数调用
fmt.Println("反转: ", Reverse(str3))
}
//反转函数
func Reverse(str string) string {
var (
result string
leng int = len(str)
)
for i := 0; i < leng; i++ {
//sprintf转换数据类型为string,使用+进行拼接
result = result + fmt.Sprintf("%c", str[leng-i-1])
}
return result
}
//输出结果如下
数据: hello world,长度: 11,数据类型: string
字节数组: [104 101 108 108 111 32 119 111 114 108 100]
数据: hello world,长度: 11,数据类型: []uint8
字节数组转字符串: hello world
反转: dlrow olleh
Sprintf的作用
package main
import "fmt"
func main() {
var a = 88
fmt.Printf("a的数值: %d , 类型: %T\n", a, a)
b := fmt.Sprintf("%d", a)
fmt.Printf("b的数值: %s , 类型: %T\n", b, b)
}
//输出结果如下
a的数值: 88 , 类型: int
b的数值: 88 , 类型: string
2. 头尾处理
prefix()函数判断前缀
suffix()函数判断后缀
使用prefix函数判断URL是否是以http://为开头,如果不是,则加上http://
使用suffix函数判断路径是否以/结尾,如果不是,则加上/为结尾
package main
import (
"fmt"
"strings"
)
func main() {
var (
url string
path string
)
fmt.Println("请输入URL和路径:")
fmt.Scanf("%s%s", &url, &path)
fmt.Printf("URL: %s\n", urlProcess(url))
fmt.Printf("路径: %s", pathProcess(path))
}
//字符串头部处理
func urlProcess(url string) string {
//判断是否以http://开头,返回布尔类型赋予result
result := strings.HasPrefix(url, "http://")
if !result {
url = fmt.Sprintf("http://%s", url)
}
return url
}
//字符串尾部处理
func pathProcess(path string) string {
//判断是否以/结尾,返回布尔类型赋予result
result := strings.HasSuffix(path, "/")
if !result {
path = fmt.Sprintf("%s/", path)
}
return path
}
终端输入如下:
PS D:\goproject\src\test\main> go run .\main.go
请输入URL和路径:
www.google.com /opt/conf/k8s
URL: http://www.google.com
路径: /opt/conf/k8s/
3. 位置索引
Index()函数判断出现在前面的位置
LastIndex()函数判断出现在末尾的位置
判断子字符串在字符串中首次出现的位置和在末尾出现的位置
package main
import (
"fmt"
"strings"
)
func main() {
var (
a = "abbaabcddccd"
str = "cd"
)
//判断str在a中首次出现的位置
head := strings.Index(a, str)
tail := strings.LastIndex(a, str)
fmt.Printf("首次出现的位置:%d\n最后出现的位置:%d\n", head, tail)
}
//输出结果如下
首次出现的位置:6
最后出现的位置:10
4. 替换
Replace()函数
格式如下:
Replace(原字符串,原字段,新字符串,新字段,替换次数)
-1表示全部替换,0表示不替换
package main
import (
"fmt"
"strings"
)
func main() {
var (
a = "abbaabcddccd"
)
//把cd替换成CD,-1表示全部替换,0表示不替换
result := strings.Replace(a, "cd", "CD", -1)
fmt.Printf("替换前: %v\n", a)
fmt.Printf("全部替换后: %v\n", result)
result1 := strings.Replace(a, "cd", "CD", 0)
fmt.Printf("不进行替换: %v\n", result1)
}
//输出结果如下
替换前: abbaabcddccd
全部替换后: abbaabCDdcCD
不进行替换: abbaabcddccd
5. 统计次数
Count()函数统计次数
package main
import (
"fmt"
"strings"
)
func main() {
var a = "abbcddcedsca"
count := strings.Count(a, "cd")
fmt.Printf("count: %v\n", count)
}
//输出结果如下
count: 1
6. 重复
Repeat()函数重复输出多次
package main
import (
"fmt"
"strings"
)
func main() {
var a = "加油~"
result := strings.Repeat(a, 3)
fmt.Printf("result: %v\n", result)
}
//输出结果如下
result: 加油~加油~加油~
7. 大小写
ToUpper()函数转换大写
ToLower()函数转换小写
package main
import (
"fmt"
"strings"
)
func main() {
var a = "hello"
//转换大写
result1 := strings.ToUpper(a)
fmt.Printf("大写: %v\n", result1)
//把上面转换的大写给转成小写
result2 := strings.ToLower(result1)
fmt.Printf("小写: %v\n", result2)
}
//输出结果如下
大写: HELLO
小写: hello
8. 去除字符
TrimSpace()函数去除空白字符
TrimLeft()从左往右删除
TrimRight()从右往左删除
- 去除首尾空白字符
package main
import (
"fmt"
"strings"
)
func main() {
var a = " abc "
fmt.Println("长度:", len(a))
//去除首位空白的字符
result1 := strings.TrimSpace(a)
fmt.Println("去除首尾空白字符:", result1, "\n长度:", len(result1))
}
//输出结果如下
长度: 5
去除首尾空白字符: abc
长度: 3
- 去除指定位置字符
package main
import (
"fmt"
"strings"
)
func main() {
var a = "this is test web"
//去掉字符串首尾部web字符
result1 := strings.Trim(a, "web")
fmt.Println("尾部去除:", result1)
//从左往右删除所有指定的字符,直到遇到不包含在指定的字符为止
result2 := strings.TrimLeft(a, "this")
//空格也需匹配删除,直到没有指定的字符可以匹配为止
result3 := strings.TrimLeft(a, "this ")
//从右往左删除所有指定的字符,直到遇到不包含在内的字符为止
result4 := strings.TrimRight(a, "web")
fmt.Println("从左往右删除:", result2)
fmt.Println("从左往右删除,有空格:", result3)
fmt.Println("从右往左删除:", result4)
}
//输出结果如下
尾部去除: this is test
从左往右删除: is test web
从左往右删除,有空格: est web
从右往左删除: this is test
9. 字符串切片处理
Fields()函数
Split()函数
- 默认识别空格进行切片处理
package main
import (
"fmt"
"strings"
)
func main() {
var str string = "abc def ghi"
//Fields函数默认识别的符号是空格
result1 := strings.Fields(str)
fmt.Printf("数据类型: %T , 数据格式: %v\n", result1, result1)
for i := 0; i < len(result1); i++ {
fmt.Println(result1[i])
}
}
//输出结果如下
数据类型: []string , 数据格式: [abc def ghi]
abc
def
ghi
- 识别其他符号分隔成切片
package main
import (
"fmt"
"strings"
)
func main() {
var str string = "abc,def,ghi"
//识别逗号进行分隔切片
result := strings.Split(str, ",")
fmt.Printf("数据类型: %T , 数据格式: %v\n", result, result)
}
//输出结果如下
数据类型: []string , 数据格式: [abc def ghi]
推荐使用Split()函数进行分隔
因为fields()函数默认只能识别空格,不能识别其他符号,而Split()函数则均可以识别
- 把切片按指定分隔符进行转换成字符串
Join()函数
package main
import (
"fmt"
"strings"
)
func main() {
//定义切片
var slice = []string{"123", "456", "789"}
fmt.Printf("切片: %v\n", slice)
//切片转换成字符串
result := strings.Join(slice, ":")
fmt.Printf("数据结构: %v , 数据类型: %T", result, result)
}
//输出结果如下
切片: [123 456 789]
数据结构: 123:456:789 , 数据类型: string
10. 数值处理
- 使用
strconv.Itoa()函数将数值转换成字符串
package main
import (
"fmt"
"strconv"
)
func main() {
var num int = 12345678
fmt.Printf("初始数据类型: %T\n", num)
fmt.Printf("初始值: %d\n", num)
//转换成字符串
result := strconv.Itoa(num)
fmt.Printf("转换后数据类型: %T\n", result)
fmt.Printf("转换后值为: %s", result)
}
//输出结果如下
初始数据类型: int
初始值: 12345678
转换后数据类型: string
转换后值为: 12345678
- 使用
Sprintf()函数将整数转换成字符串
package main
import (
"fmt"
)
func main() {
var num int = 12345678
fmt.Printf("初始数据类型: %T\n", num)
//使用Sprintf()转换成字符串,可以实现多类型的转换
result := fmt.Sprintf("%d", num)
fmt.Printf("转换后数据类型:%T\n", result)
}
//输出结果如下
初始数据类型: int
转换后数据类型:string
- 使用
strconv.Atoi()函数进行字符串转换整数
package main
import (
"fmt"
"strconv"
)
func main() {
var str string = "12345678"
//字符串转整数
result, err := strconv.Atoi(str)
//如果有转换过程中有错,就抛出错误,没有错就返回数据类型
if err == nil {
fmt.Printf("数据类型: %T\n", result)
} else {
fmt.Println(err)
}
}
//输出结果
数据类型: int

Go 语言字符串常见操作的更多相关文章
- python字符串常见操作
字符串常见操作 如有字符串mystr = 'hello world itcast and itcastcpp',以下是常见的操作 <1>find 检测 str 是否包含在 mystr中,如 ...
- python基础学习-字符串常见操作
字符串常见操作 索引 s = "abcdefg" # 字符串数据,切片后取出的数据都是字符串类型 # 从左至右取值:从0开始 # 从右向左取值:从-1开始 print(" ...
- C语言字符串的操作
C语言字符串操作函数 1. 字符串反转 - strRev2. 字符串复制 - strcpy3. 字符串转化为整数 - atoi4. 字符串求长 - strlen5. 字符串连接 - strcat6. ...
- Python中字符串常见操作
(1)find 查找 格式:mystr.find(str, start, end) 例如: mystr.find(str, start=0, end=len(mystr)) 作用:检测str是否包含在 ...
- Shell 字符串常见操作
参考文章:http://blog.csdn.net/chen_jp/article/details/8922582 一 字符替换 origin=原字符串 str=替换后的字符串 替换命令: str= ...
- python中字符串常见操作(二)
# 可迭代对象有:字典,列表,元组,字符串,集合 str1 = '192.168.1.1' str2 = 'as df gh jk' str3 = '小李子' str4 = ['aa','bb','c ...
- JAVA中字符串常见操作
String str1="hello,world";String str2="Hello,World"; 1.字符串的比较:例,System.out.print ...
- C#字符串常见操作总结
string类常用的方法和总结小记
- C语言 字符串操作 笔记
/* C语言字符串的操作笔记 使用代码和注释结合方式记录 */ # include <stdio.h> # include <string.h> int main(void) ...
随机推荐
- 在idea中新建完springboot项目的时候遇到问题(右键没有class选择;控制台报错:Could not transfer artifact org.apache.tomcat.embed:tomcat-embed-core:jar:9.0.60 from/to central ....)
一.在idea中新建完springboot项目的时候遇到问题 问题1:右键没有class选择 解决:之所以会如此,是因为项目还没完成创建完成,解决:只需等等即可,等到完全创建完成即可 问题2(报tom ...
- 摆烂期的Android学习笔记一
Android大致分为四层架构1.Linux内核层:提供各种硬件驱动,如显示驱动,音频驱动,相机驱 动,蓝牙驱动.... 2.系统运行库层:通过C/c++库为android地图提供支持 3.应用框架层 ...
- 12.9 Override
12.9 Override 静态方法 父类的引用可以指向子类静态方法(用static修饰的方法)的调用只和左边定义的数据类型有关,如: public class Person { public sta ...
- TypeScript编译tsconfig.json配置
配置预览 { "include": ["src/**/*"], "exclude": ["ndoe_modules", ...
- 通过R Studio用Markdown写Beamer
技术背景 在写一些学术演示文档时,经常有可能用到Beamer--一种Latex的学术风PPT模板,比如下图所示的这种: 这种风格的演示文档有几个明显的优点:简约.严肃.可以用Latex敲公式和推导.可 ...
- keybd_event 在F按键系列不起作用的解决办法
最近给公司做自动化测试工具,主要用到的功能是模拟鼠标键盘录制回放.一切都很完美了,但在客户大机系统上使用的时候,发现F1-F24系列按键无法正确使用,查了很多资料,主要有2个方面的原因: 1.一些游戏 ...
- spring-boot-learning-REST风格网站
什么是REST风格: Representational State Transfer :表现层状态转换,实际上是一种风格.标准,约定 首先需要有资源才能表现, 所以第一个名词是" 资源&qu ...
- 什么是基于 Java 的 Spring 注解配置?
基于 Java 的配置,允许你在少量的 Java 注解的帮助下,进行你的大部分 Spring 配置而非通过 XML 文件. 以@Configuration 注解为例,它用来标记类可以当做一个 bean ...
- memcached 与 redis 的区别?
1.Redis 不仅仅支持简单的 k/v 类型的数据,同时还提供 list,set,zset,hash 等数据结构的存储.而 memcache 只支持简单数据类型,需要客户端自己处理复 杂对象 2.R ...
- @Qualifier 注解 ?
当有多个相同类型的 bean 却只有一个需要自动装配时,将@Qualifier 注解和 @Autowire 注解结合使用以消除这种混淆,指定需要装配的确切的 bean.