当前位置: 首页 > news >正文

golang strings包的基本操作

文章目录

      • golang 的字符串函数
        • EqualFold
        • HasPrefix
        • HasSuffix
        • Contains
        • ContainsRune
        • ContainsAny
        • Count
        • Index
        • IndexByte
        • IndexRune
        • IndexAny
        • IndexFunc
        • LastIndex
        • LastIndexAny
        • LastIndexFunc
        • Title
        • ToLower
        • ToLowerSpecial
        • ToUpper
        • ToUpperSpecial
        • ToTitle
        • ToTitleSpecial
        • Repeat
        • Replace
        • Map
        • Trim
        • TrimSpace
        • TrimFunc
        • TrimLeft
        • TrimPrefix
        • TrimRight
        • TrimRightFunc
        • TrimSuffix
        • Fields
        • Fields(s string) []string
        • FieldsFunc
        • Split
        • SplitN
        • SplitAfter
        • SplitAfterN
        • Reader
        • NewReader
        • (*Reader) Len
        • (*Reader) Read
        • (*Reader) ReadAt
        • Replacer
        • NewReplacer
        • (*Replacer) Replace
        • (*Replacer) WriteString

golang 的字符串函数

strings包实现了用于操作字符的简单函数.
golang 的字符串常用内建函数如下:

序号方法描述
1EqualFold判断两个utf-8编码字符串(将unicode大写、小写、标题三种格式字符视为相同)是否相同。
2HasPrefix判断s是否有前缀字符串prefix。
3HasSuffix判断s是否有后缀字符串suffix。
4Contains断字符串s是否包含子串substr
5ContainsRune判断字符串s是否包含utf-8码值r。
6ContainsAny判断字符串s是否包含字符串chars中的任一字符。
7Count返回字符串s中有几个不重复的sep子串。
8Index子串sep在字符串s中第一次出现的位置,不存在则返回-1。
9IndexByte字符c在s中第一次出现的位置,不存在则返回-1。
10IndexRuneunicode码值r在s中第一次出现的位置,不存在则返回-1。
11IndexAny字符串chars中的任一utf-8码值在s中第一次出现的位置,如果不存在或者chars为空字符串则返回-1。
12IndexFuncs中第一个满足函数f的位置i(该处的utf-8码值r满足f®==true),不存在则返回-1。
13LastIndex子串sep在字符串s中最后一次出现的位置,不存在则返回-1。
14LastIndexAny字符串chars中的任一utf-8码值在s中最后一次出现的位置,如不存在或者chars为空字符串则返回-1。
15LastIndexFuncs中最后一个满足函数f的unicode码值的位置i,不存在则返回-1。
16Title返回s中每个单词的首字母都改为标题格式的字符串拷贝。BUG: Title用于划分单词的规则不能很好的处理Unicode标点符号。
17ToLower返回将所有字母都转为对应的小写版本的拷贝。
18ToLowerSpecial使用_case规定的字符映射,返回将所有字母都转为对应的小写版本的拷贝。
19ToUpper返回将所有字母都转为对应的大写版本的拷贝。
20ToUpperSpecial使用_case规定的字符映射,返回将所有字母都转为对应的大写版本的拷贝。返回将所有字母都转为对应的大写版本的拷贝。
21ToTitle返回将所有字母都转为对应的标题版本的拷贝。
22ToTitleSpecial使用_case规定的字符映射,返回将所有字母都转为对应的标题版本的拷贝。
23Repeat返回count个s串联的字符串。
24Replace返回将s中前n个不重叠old子串都替换为new的新字符串,如果n<0会替换所有old子串。
25Map将s的每一个unicode码值r都替换为mapping®,返回这些新码值组成的字符串拷贝。如果mapping返回一个负值,将会丢弃该码值而不会被替换。(返回值中对应位置将没有码值)
26Trim返回将s前后端所有cutset包含的utf-8码值都去掉的字符串。
27TrimSpace返回将s前后端所有空白(unicode.IsSpace指定)都去掉的字符串。
28TrimFunc返回将s前后端所有满足f的unicode码值都去掉的字符串。
29TrimLeft返回将s前端所有cutset包含的utf-8码值都去掉的字符串。
30TrimLeftFunc返回将s前端所有满足f的unicode码值都去掉的字符串。
31TrimPrefix返回去除s可能的前缀prefix的字符串。
32TrimRight返回将s后端所有cutset包含的utf-8码值都去掉的字符串。
33TrimRightFunc返回将s后端所有满足f的unicode码值都去掉的字符串。
34TrimSuffix返回去除s可能的后缀suffix的字符串。
35Fields返回将字符串按照空白(unicode.IsSpace确定,可以是一到多个连续的空白字符)分割的多个字符串。如果字符串全部是空白或者是空字符串的话,会返回空切片。
36FieldsFunc类似Fields,但使用函数f来确定分割符(满足f的unicode码值)。如果字符串全部是分隔符或者是空字符串的话,会返回空切片。
37Split用去掉s中出现的sep的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。
38SplitN用去掉s中出现的sep的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。参数n决定返回的切片的数目: n > 0 : 返回的切片最多n个子字符串;最后一个子字符串包含未进行切割的部分。n == 0: 返回nil n < 0 : 返回所有的子字符串组成的切片
39SplitAfter用从s中出现的sep后面切断的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。
40SplitAfterN用从s中出现的sep后面切断的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。参数n决定返回的切片的数目:n > 0 : 返回的切片最多n个子字符串;最后一个子字符串包含未进行切割的部分。n == 0: 返回niln < 0 : 返回所有的子字符串组成的切
41Join将一系列字符串连接为一个字符串,之间用sep来分隔。

关于type Reader 和 type Replacer操作文档链接:
https://studygolang.com/pkgdoc

EqualFold

func EqualFold(s, t string) bool
判断两个utf-8编码字符串(将unicode大写、小写、标题三种格式字符视为相同)是否相同。

	var name1 = "艾拉"var name2 = "艾拉"var name3 = "伊雷娜"fmt.Println(strings.EqualFold(name1, name2))	// turefmt.Println(strings.EqualFold(name1, name3))	// false
HasPrefix

func HasPrefix(s, prefix string) bool
判断s是否有前缀字符串prefix。

	var name1 = "艾拉"var name2 = "伊"var name3 = "艾"fmt.Println(strings.HasPrefix(name1, name2))	// falsefmt.Println(strings.HasPrefix(name1, name3))	// true
HasSuffix

func HasSuffix(s, suffix string) bool
判断s是否有后缀字符串suffix。

	var name1 = "艾拉"var name2 = "拉"var name3 = "艾"fmt.Println(strings.HasSuffix(name1, name2)) // truefmt.Println(strings.HasSuffix(name1, name3)) // false
Contains

func Contains(s, substr string) bool
判断字符串s是否包含子串substr。
Contains() 函数用于检查字符串 str 是否包含子字符串 substr。
它基于字节的比较,判断 str 中是否存在与 substr 相同的字节序列。
判断一个字符串中是否包含一个普通的ASCII字符比ContainsRune更为高效

	var string1 = "可塑性记忆"var string2 = "记忆"var string3 = "艾"fmt.Println(strings.Contains(string1, string2))	// truefmt.Println(strings.Contains(string1, string3))	// false
ContainsRune

func ContainsRune(s string, r rune) bool
判断字符串s是否包含utf-8码值r。

	var string1 = "可塑性记忆"var string2 = '记' // 单引号 ' 用于表示一个 Unicode 码点,而双引号 " 用于表示一个字符串var string3 = '艾'fmt.Println(string2, string3)                       // 35760 33406fmt.Println(strings.ContainsRune(string1, string2)) // truefmt.Println(strings.ContainsRune(string1, string3)) // false
ContainsAny

func ContainsAny(s, chars string) bool
判断字符串s是否包含字符串chars中的任一字符。

	var string1 = "可塑性记忆"var string2 = "qwq记"fmt.Println(strings.ContainsAny(string1, string2)) // true// 简单的说string2 只要有一个字符在string1里面就会返回true,一个都没有就会返回false
Count

func Count(s, sep string) int
返回字符串s中有几个不重复的sep子串。

	var string1 = "可塑性记忆,艾拉艾拉"var string2 = "艾拉"fmt.Println(strings.Count(string1, string2)) // 2
Index

func Index(s, sep string) int
子串sep在字符串s中第一次出现的位置,不存在则返回-1。

	var string1 = "可塑性记忆,艾拉艾拉"var string2 = "艾拉"//在 UTF-8 编码中 中文字符占用 3 个字节,而英文字符占用 1 个字节.   5*3 + 1fmt.Println(strings.Index(string1, string2)) // 16var string3 = "yanilo"var string4 = "l"fmt.Println(strings.Index(string3, string4)) // 4
IndexByte

func IndexByte(s string, c byte) int
字符c在s中第一次出现的位置,不存在则返回-1。
IndexByte 是一个函数,用于在字节切片中查找指定字节的索引位置

	byteSlice := []byte{10, 20, 30, 40, 50}index := bytes.IndexByte(byteSlice, 30)fmt.Println(index) // 输出:2
IndexRune

func IndexRune(s string, r rune) int
unicode码值r在s中第一次出现的位置,不存在则返回-1。
IndexRune 是一个函数,字符串中使用 strings.IndexRune 函数查找 Unicode 字符的索引位置时,返回的索引位置是以 Unicode 码点为单位的,而不是字节位置

	str := "ke可塑性记忆,艾拉艾拉"index := strings.IndexRune(str, '艾')fmt.Println(index) // 输出:18
IndexAny

func IndexAny(s, chars string) int
字符串chars中的任一utf-8码值在s中第一次出现的位置,如果不存在或者chars为空字符串则返回-1。

	str := "ke可塑性记忆,艾拉艾拉"charset := "艾塑"index := strings.IndexAny(str, charset)fmt.Println(index) // 输出:5
IndexFunc

func IndexFunc(s string, f func(rune) bool) int
s中第一个满足函数f的位置i(该处的utf-8码值r满足f®==true),不存在则返回-1。

	f := func(c rune) bool {return unicode.Is(unicode.Han, c)}fmt.Println(strings.IndexFunc("Hello, 世界", f))    // 输出:7fmt.Println(strings.IndexFunc("Hello, world", f))   // 输出:-1
LastIndex

func LastIndex(s, sep string) int
子串sep在字符串s中最后一次出现的位置,不存在则返回-1。

	str := "Hello, Hello, Hello"substr := "Hello"lastIndex := strings.LastIndex(str, substr)fmt.Println(lastIndex) // 输出:14
LastIndexAny

func LastIndexAny(s, chars string) int
字符串chars中的任一utf-8码值在s中最后一次出现的位置,如不存在或者chars为空字符串则返回-1。

	str := "Hello, World!"chars := "o!"lastIndex := strings.LastIndexAny(str, chars)fmt.Println(lastIndex) // 输出:12
LastIndexFunc

func LastIndexFunc(s string, f func(rune) bool) int
s中最后一个满足函数f的unicode码值的位置i,不存在则返回-1。

	str := "Hello, World!"// unicode.IsSpace 是一个函数,用于判断一个 Unicode 字符是否为空格字符。lastIndex := strings.LastIndexFunc(str, unicode.IsSpace)fmt.Println(lastIndex) // 输出:6
Title

func Title(s string) string
返回s中每个单词的首字母都改为标题格式的字符串拷贝。

	str := "hello, world!"titleString := strings.Title(str)fmt.Println(titleString) // 输出:Hello, World!

BUG: Title用于划分单词的规则不能很好的处理Unicode标点符号。

ToLower

func ToLower(s string) string
返回将所有字母都转为对应的小写版本的拷贝。

	str := "Hello, World!"lowerString := strings.ToLower(str)fmt.Println(lowerString) // 输出:hello, world!
ToLowerSpecial

func ToLowerSpecial(_case unicode.SpecialCase, s string) string
使用_case规定的字符映射,返回将所有字母都转为对应的小写版本的拷贝。
ToLowerSpecial 是一个字符串处理函数,用于将字符串中的所有字符转换为小写形式,但可以指定特定的语言环境。

	str := "HÉLLÖ, WÖRLD!"locale := unicode.TurkishCaselowerString := strings.ToLowerSpecial(locale, str)fmt.Println(lowerString) // 输出:héllö, wörld!
ToUpper

func ToUpper(s string) string
返回将所有字母都转为对应的大写版本的拷贝。
ToUpper 是一个字符串处理函数,用于将字符串中的所有字符转换为大写形式。

	str := "Hello, World!"upperString := strings.ToUpper(str)fmt.Println(upperString) // 输出:HELLO, WORLD!
ToUpperSpecial

func ToUpperSpecial(_case unicode.SpecialCase, s string) string
使用_case规定的字符映射,返回将所有字母都转为对应的大写版本的拷贝。
ToUpperSpecial 是一个字符串处理函数,用于将字符串中的所有字符转换为大写形式,但可以指定特定的语言环境。

	str := "héllö, wörld!"locale := unicode.TurkishCaseupperString := strings.ToUpperSpecial(locale, str)fmt.Println(upperString) // 输出:HÉLLÖ, WÖRLD!
ToTitle

func ToTitle(s string) string
返回将所有字母都转为对应的标题版本的拷贝。

	str := "hello, world!"titleString := strings.ToTitle(str)fmt.Println(titleString) // 输出:HELLO, WORLD!
ToTitleSpecial

func ToTitleSpecial(_case unicode.SpecialCase, s string) string
使用_case规定的字符映射,返回将所有字母都转为对应的标题版本的拷贝。
ToTitleSpecial 是一个字符串处理函数,用于将字符串中的所有字符转换为标题形式,但可以指定特定的语言环境。

	str := "héllö, wörld!"locale := unicode.TurkishCasetitleString := strings.ToTitleSpecial(locale, str)fmt.Println(titleString) // 输出:HÉLLÖ, WÖRLD!
Repeat

func Repeat(s string, count int) string
返回count个s串联的字符串。
Repeat 是一个字符串处理函数,用于将指定的字符串重复多次以生成一个新的字符串。

	str := "hello"repeatedString := strings.Repeat(str, 3)fmt.Println(repeatedString) // 输出:hellohellohello
Replace

func Replace(s, old, new string, n int) string
返回将s中前n个不重叠old子串都替换为new的新字符串,如果n<0会替换所有old子串。
Replace 是一个字符串处理函数,用于将字符串中的指定子串替换为新的子串。

	str := "Hello, World!"newStr := strings.Replace(str, "World", "Golang", -1)fmt.Println(newStr) // 输出:Hello, Golang!
Map

func Map(mapping func(rune) rune, s string) string
将s的每一个unicode码值r都替换为mapping®,返回这些新码值组成的字符串拷贝。如果mapping返回一个负值,将会丢弃该码值而不会被替换。(返回值中对应位置将没有码值)
strings.Map 是 Go 语言中的一个字符串处理函数,用于对字符串中的每个字符执行指定的操作,并返回一个新的字符串。

	str := "Hello, World!"newStr := strings.Map(func(r rune) rune {if r == '!' {return '#'}return r}, str)fmt.Println(newStr) // 输出:Hello, World#
Trim

func Trim(s string, cutset string) string
返回将s前后端所有cutset包含的utf-8码值都去掉的字符串。
Trim 是一个常见的字符串处理操作,用于去除字符串的首尾指定字符或字符集合。

	str := "---   Hello, World!   ----"trimmedStr := strings.Trim(str, "-")fmt.Println(trimmedStr) // 输出:   Hello, World!trimmedStr2 := strings.Trim(trimmedStr, " ")fmt.Println(trimmedStr2) // 输出:Hello, World!
TrimSpace

func TrimSpace(s string) string
返回将s前后端所有空白(unicode.IsSpace指定)都去掉的字符串。
TrimSpace 是 Go 语言中的一个字符串处理函数,用于去除字符串首尾的空格符(包括空格、制表符和换行符)。

	str := "   Hello, World!   "trimmedStr := strings.TrimSpace(str)fmt.Println(trimmedStr) // 输出:Hello, World!
TrimFunc

func TrimFunc(s string, f func(rune) bool) string
返回将s前后端所有满足f的unicode码值都去掉的字符串。
TrimFunc 是 Go 语言中的一个字符串处理函数,用于根据自定义的函数逻辑来去除字符串的首尾字符。

	str := "   Hello, World!   "// unicode.IsSpace 是一个函数,用于判断一个 Unicode 字符是否为空格字符。trimmedStr := strings.TrimFunc(str, unicode.IsSpace)fmt.Println(trimmedStr) // 输出:Hello, World!
TrimLeft

func TrimLeft(s string, cutset string) string
返回将s前端所有cutset包含的utf-8码值都去掉的字符串。
TrimLeft 是 Go 语言中的一个字符串处理函数,用于去除字符串开头的指定字符。

	str := "!!!Hello, World!!!"trimmedStr := strings.TrimLeft(str, "!")fmt.Println(trimmedStr) // 输出:Hello, World!!!

func TrimLeftFunc
func TrimLeftFunc(s string, f func(rune) bool) string
返回将s前端所有满足f的unicode码值都去掉的字符串。
TrimLeftFunc 是 Go 语言中的一个字符串处理函数,用于根据自定义的函数逻辑来去除字符串开头的字符。

	str := "!!!Hello, World!!!"// unicode.IsPunct 是 Go 语言中的一个函数,用于判断给定的 Unicode 字符是否为标点符号。trimmedStr := strings.TrimLeftFunc(str, unicode.IsPunct)fmt.Println(trimmedStr) // 输出:Hello, World!!!
TrimPrefix

func TrimPrefix(s, prefix string) string
返回去除s可能的前缀prefix的字符串。
TrimPrefix 是 Go 语言中的一个字符串处理函数,用于去除字符串开头的指定前缀。

	str := "Hello, World!"trimmedStr := strings.TrimPrefix(str, "Hello, ")fmt.Println(trimmedStr) // 输出:World!
TrimRight

func TrimRight(s string, cutset string) string
返回将s后端所有cutset包含的utf-8码值都去掉的字符串。
TrimRight 是 Go 语言中的一个字符串处理函数,用于去除字符串末尾的指定字符集合。

	str := "Hello, World!!!"trimmedStr := strings.TrimRight(str, "!")fmt.Println(trimmedStr) // 输出:Hello, World
TrimRightFunc

func TrimRightFunc(s string, f func(rune) bool) string
返回将s后端所有满足f的unicode码值都去掉的字符串。
TrimRightFunc 是 Go 语言中的一个字符串处理函数,用于根据自定义的函数逻辑去除字符串末尾的字符。

	str := "Hello, World!!!"// unicode.IsPunct 是 Go 语言中的一个函数,用于判断给定的 Unicode 字符是否为标点符号。trimmedStr := strings.TrimRightFunc(str, unicode.IsPunct)fmt.Println(trimmedStr) // 输出:Hello, World
}
TrimSuffix

func TrimSuffix(s, suffix string) string
返回去除s可能的后缀suffix的字符串。
TrimSuffix 是 Go 语言中的一个字符串处理函数,用于去除字符串末尾的指定后缀。

	str := "Hello, World!!!"trimmedStr := strings.TrimSuffix(str, "!!!")fmt.Println(trimmedStr) // 输出:Hello, World
Fields
Fields(s string) []string

返回将字符串按照空白(unicode.IsSpace确定,可以是一到多个连续的空白字符)分割的多个字符串。如果字符串全部是空白或者是空字符串的话,会返回空切片。
strings.Fields 是 Go 语言中的一个字符串处理函数,用于将字符串按空白字符分割成多个子字符串,并返回一个子字符串的切片。

	str := "Hello   World\tGolang\nProgramming"fields := strings.Fields(str)fmt.Println(fields)		// [Hello World Golang Programming]for _, field := range fields {fmt.Println(field)//Hello//World//Golang//Programming}
FieldsFunc

func FieldsFunc(s string, f func(rune) bool) []string
类似Fields,但使用函数f来确定分割符(满足f的unicode码值)。如果字符串全部是分隔符或者是空字符串的话,会返回空切片。
FieldsFunc 是 Go 语言中的一个字符串处理函数,用于将字符串按照自定义的分隔函数进行分割,并返回一个子字符串的切片。

	str := "Hello, World! Golang Programming"// unicode.IsSpace 是 Go 语言中的一个函数,用于判断一个 Unicode 字符是否为空白字符。fields := strings.FieldsFunc(str, func(r rune) bool {return unicode.IsSpace(r) || r == '!'})fmt.Println(fields) // [Hello, World Golang Programming]for _, field := range fields {fmt.Println(field)// Hello,// World// Golang// Programming}
Split

func Split(s, sep string) []string
用去掉s中出现的sep的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。

	str := "Hello, World! Golang Programming"fields := strings.Split(str, ", ")fmt.Println(fields) // [Hello World! Golang Programming]for _, field := range fields {fmt.Println(field)// Hello// World! Golang Programming}
SplitN

func SplitN(s, sep string, n int) []string
用去掉s中出现的sep的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。参数n决定返回的切片的数目:
SplitN 是 Go 语言中的一个字符串处理函数,用于将字符串按照指定的分隔符进行分割,并返回一个子字符串的切片。与 Split 函数不同的是,SplitN 函数可以指定最大分割次数。
n > 0 : 返回的切片最多n个子字符串;最后一个子字符串包含未进行切割的部分。
n == 0: 返回nil
n < 0 : 返回所有的子字符串组成的切片

SplitN 是 Go 语言中的一个字符串处理函数,用于将字符串按照指定的分隔符进行分割,并返回一个子字符串的切片。与 Split 函数不同的是,SplitN 函数可以指定最大分割次数。

	str := "Hello, World! Golang Programming"fields := strings.SplitN(str, ", ", 2)fmt.Println(fields) // [Hello World! Golang Programming]for _, field := range fields {fmt.Println(field)// Hello// World! Golang Programming}
SplitAfter

func SplitAfter(s, sep string) []string
用从s中出现的sep后面切断的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。
SplitAfter 是 Go 语言中的一个字符串处理函数,用于将字符串按照指定的分隔符进行分割,并返回一个子字符串的切片。与 Split 函数不同的是,SplitAfter 函数在分割时会保留分隔符。

	str := "Hello, World! Golang Programming."fields := strings.SplitAfter(str, ", ")fmt.Println(fields) // [Hello,  World! Golang Programming.]for _, field := range fields {fmt.Println(field)// Hello,// World! Golang Programming.}
SplitAfterN

func SplitAfterN(s, sep string, n int) []string
用从s中出现的sep后面切断的方式进行分割,会分割到结尾,并返回生成的所有片段组成的切片(每一个sep都会进行一次切割,即使两个sep相邻,也会进行两次切割)。如果sep为空字符,Split会将s切分成每一个unicode码值一个字符串。参数n决定返回的切片的数目:

n > 0 : 返回的切片最多n个子字符串;最后一个子字符串包含未进行切割的部分。
n == 0: 返回nil
n < 0 : 返回所有的子字符串组成的切
Example
func Join
func Join(a []string, sep string) string
将一系列字符串连接为一个字符串,之间用sep来分隔。

SplitAfterN 是 Go 语言中的一个字符串处理函数,用于将字符串按照指定的分隔符进行分割,并返回一个子字符串的切片。与 SplitN 函数不同的是,SplitAfterN 函数在分割时会保留分隔符。

	str := "Hello, World! Golang Programming."fields := strings.SplitAfterN(str, ", ", 2)fmt.Println(fields) // [Hello,  World! Golang Programming.]for _, field := range fields {fmt.Println(field)// Hello,// World! Golang Programming.}
Reader

type Reader struct {
// 内含隐藏或非导出字段
}
Reader类型通过从一个字符串读取数据,实现了io.Reader、io.Seeker、io.ReaderAt、io.WriterTo、io.ByteScanner、io.RuneScanner接口。
Reader 是 Go 语言中的一个接口(interface),定义了读取操作的基本方法。Reader 接口可以用于从不同的数据源(如文件、网络连接、内存等)读取数据。

	reader := strings.NewReader("Hello, World!")buffer := make([]byte, 5)for {n, err := reader.Read(buffer)if err == io.EOF {break}/*io.EOF 是 Go 语言中的一个预定义错误变量,表示输入或输出操作已达到文件末尾(End of File)。EOF 是 "End of File" 的缩写。当读取操作(如从文件、网络连接或其他数据源读取数据)达到文件末尾时,读取函数通常会返回 io.EOF 错误,以指示已经读取完所有的数据。*/fmt.Printf("Read %d bytes: %s\n", n, buffer[:n])// Read 5 bytes: Hello// Read 5 bytes: , Wor// Read 3 bytes: ld!}
NewReader

func NewReader(s string) *Reader
NewReader创建一个从s读取数据的Reader。本函数类似bytes.NewBufferString,但是更有效率,且为只读的。

(*Reader) Len

func (r *Reader) Len() int
Len返回r包含的字符串还没有被读取的部分。

(*Reader) Read

func (r *Reader) Read(b []byte) (n int, err error)
func (*Reader) ReadByte
func (r *Reader) ReadByte() (b byte, err error)
func (*Reader) UnreadByte
func (r *Reader) UnreadByte() error
func (*Reader) ReadRune
func (r *Reader) ReadRune() (ch rune, size int, err error)
func (*Reader) UnreadRune
func (r *Reader) UnreadRune() error
func (*Reader) Seek
func (r *Reader) Seek(offset int64, whence int) (int64, error)
Seek实现了io.Seeker接口。

(*Reader) ReadAt

func (r *Reader) ReadAt(b []byte, off int64) (n int, err error)
func (*Reader) WriteTo
func (r *Reader) WriteTo(w io.Writer) (n int64, err error)
WriteTo实现了io.WriterTo接口。

Replacer

type Replacer struct {
// 内含隐藏或非导出字段
}
Replacer类型进行一系列字符串的替换。

NewReplacer

func NewReplacer(oldnew …string) Replacer
使用提供的多组old、new字符串对创建并返回一个
Replacer。替换是依次进行的,匹配时不会重叠。

(*Replacer) Replace

func (r *Replacer) Replace(s string) string
Replace返回s的所有替换进行完后的拷贝。

(*Replacer) WriteString

func (r *Replacer) WriteString(w io.Writer, s string) (n int, err error)
WriteString向w中写入s的所有替换进行完后的拷贝。

相关文章:

golang strings包的基本操作

文章目录 golang 的字符串函数EqualFoldHasPrefixHasSuffixContainsContainsRuneContainsAnyCountIndexIndexByteIndexRuneIndexAnyIndexFuncLastIndexLastIndexAnyLastIndexFuncTitleToLowerToLowerSpecialToUpperToUpperSpecialToTitleToTitleSpecialRepeatReplaceMapTrimTri…...

高效解决在本地打开可视化服务器端的tensorboard

文章目录 问题解决方案 问题 由于连着远程服务器构建模型&#xff0c;但是想在本地可视化却做不到&#xff0c;不要想当然天真的以为CTRLC点击链接http://localhost:6006就真能在本地打开tensorboard。你电脑都没连接服务器&#xff0c;只是pycharm连上了而已 解决方案 你需要…...

Spring Boot Actuator 2.2.5 基本使用

1. pom文件 &#xff0c;添加 Actuator 依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> 2.application.properties 文件中添加以下配置 …...

字符串相似度匹配算法_莱茵斯坦距离算法

package day0330;public class LevenshteinDistanceUtil {public static void main(String[] args) {String a "WN64 F98";String b "WN64 F98 ";System.out.println("相似度:" getSimilarityRatio(a, b));}/*** 获取两字符串的相似度* * par…...

【EI会议征稿】第九届电气、电子和计算机工程研究国际学术研讨会 (ISAEECE 2024)

第九届电气、电子和计算机工程研究国际学术研讨会 (ISAEECE 2024) 2024 9th International Symposium on Advances in Electrical, Electronics and Computer Engineering 第九届电气、电子和计算机工程研究国际学术研讨会(ISAEECE 2024&#xff09;将于2024年3月1-5日在南…...

Maven Helper插件——实现一键Maven依赖冲突问题

总结/朱季谦 业余在一个SpringBoot项目集成Swagger2时&#xff0c;启动过程一直出现以下报错信息—— An attempt was made to call a method that does not exist. The attempt was made from the following location: ​ springfox.documentation.schema.DefaultModelDepe…...

理解位运算的规则

关卡名 理解位运算的规则 我会了✔️ 内容 1.理解位运算的基本规则 ✔️ 2.理解移位的原理以及与乘除的关系 ✔️ 3.掌握位运算的常用技巧 ✔️ 在学习位操作之前&#xff0c;我们先明确数据在计算机中怎么表示的。我们明确原码、反码和补码的概念和表示方法&#xff0c;之…...

Android Bitmap 使用Vukan、RenderEffect、GLSL实现模糊

文章目录 Android Bitmap 使用Vukan、RenderEffect、GLSL实现模糊使用 RenderEffect 模糊使用 Vukan 模糊使用 GLSL 模糊RS、Vukan、RenderEffect、GLSL 效率对比 Android Bitmap 使用Vukan、RenderEffect、GLSL实现模糊 本文首发地址 https://blog.csdn.net/CSqingchen/articl…...

Vue H5页面长按保存为图片

安装依赖&#xff1a;npm install html2canvas -d <template><div class"index"><div id"captureId" class"capture" v-show"firstFlag"><ul><li>1</li><li>2</li><li>3<…...

【Web】UUCTF 2022 新生赛 个人复现

目录 ①websign ②ez_rce ③ez_upload ④ez_unser ⑤ezsql ⑥ezpop ⑦funmd5 ⑧phonecode ⑨ezrce ①websign 右键打不开&#xff0c;直接抓包发包看源码 ②ez_rce “反引号” 在PHP中会被当作SHELL命令执行 ?codeprintf(l\s /); ?codeprintf(ta\c /ffffffffffl…...

设置python下载包代理

使用场景 正常网络情况下我们安装如果比较多的python包时&#xff0c;会选择使用pip install -r requirements.txt -i https://pypi.douban.com/simple --trusted-hostpypi.douban.com这种国内的镜像来加快下载速度。 但是&#xff0c;当这台被限制上网时&#xff08;公司安全…...

nginx 配置前端项目添加https

可申请阿里云免费证书 步骤省略… nginx 配置 server {listen 8050; #默认80端口 如果需要所有访问地址都是https 需要注释listen 8443 ssl; #https 访问的端口 &#xff0c;默认443server_name 192.168.128.XX; #域名 或 ip# 增加ssl#填写证书文件…...

人群计数CSRNet的pytorch实现

本文中对CSRNet: Dilated Convolutional Neural Networks for Understanding the Highly Congested Scenes&#xff08;CVPR 2018&#xff09;中的模型进行pytorch实现 import torch;import torch.nn as nn from torchvision.models import vgg16 vggvgg16(pretrained1)import…...

【HTTP协议】简述HTTP协议的概念和特点

&#x1f38a;专栏【网络编程】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【如愿】 &#x1f970;欢迎并且感谢大家指出小吉的问题 文章目录 &#x1f33a;概念&#x1f33a;特点&#x1f384;请求协议&#x1f384;响应协议…...

经典神经网络——AlexNet模型论文详解及代码复现

一、背景 AlexNet是在2012年由Alex Krizhevsky等人提出的&#xff0c;该网络在2012年的ImageNet大赛上夺得了冠军&#xff0c;并且错误率比第二名高了很多。Alexnet共有8层结构&#xff0c;前5层为卷积层&#xff0c;后三层为全连接层。 论文地址&#xff1a;ImageNet Classif…...

flutter开发实战-轮播Swiper更改Custom_layout样式中Widget层级

flutter开发实战-轮播Swiper更改Custom_layout样式中Widget层级 在之前的开发过程中&#xff0c;需要实现卡片轮播效果&#xff0c;但是卡片轮播需要中间大、两边小一些的效果&#xff0c;这里就使用到了Swiper。具体效果如视频所示 添加链接描述 这里需要的效果是中间大、两边…...

【Flutter】graphic图表实现自定义tooltip

renderer graphic中tooltip的TooltipGuide类提供了renderer方法&#xff0c;接收三个参数Size类型&#xff0c;Offset类型&#xff0c;Map<int, Tuple>类型。可查到的文档是真的少&#xff0c;所以只能在源码中扒拉例子&#xff0c;做符合需求的修改。 官方github示例 …...

手机上的记事本怎么打开?安卓手机通用的记事本APP

有不少上班族发现&#xff0c;自己想要在电脑上随手记录一些工作文字内容&#xff0c;直接使用电脑上的记事本工具来编辑文字是比较便捷的。但是如果想要在手机上记录文字内容&#xff0c;就找不到手机上的记事本了。那么手机上的记事本怎么打开&#xff1f;安卓手机通用的记事…...

一起学docker系列之十五深入了解 Docker Network:构建容器间通信的桥梁

目录 1 前言2 什么是 Docker Network3 Docker Network 的不同模式3.1 桥接模式&#xff08;Bridge&#xff09;3.2 Host 模式3.3 无网络模式&#xff08;None&#xff09;3.4 容器模式&#xff08;Container&#xff09; 4 Docker Network 命令及用法4.1 docker network ls4.2 …...

前端OFD文件预览(vue案例cafe-ofd)

0、提示 下面只有vue的使用示例demo &#xff0c;官文档参考 cafe-ofd - npm 其他平台可以参考 ofd - npm 官方线上demo: ofd 1、安装包 npm install cafe-ofd --save 2、引入 import cafeOfd from cafe-ofd import cafe-ofd/package/index.css Vue.use(cafeOfd) 3、使…...

Java[list/set]通用遍历方法之Iterator

需求&#xff1a;输入一个字符串 将其拆解成单个汉字 然后一行一个输出 这里要求使用到Arraylist集合实现方法Itrator遍历的原理import java.util.ArrayList; import java.util.Collection; import java.util.Iterator;public class Main{public static void main(String[] arg…...

ubuntu/vscode下的c/c++开发之-CMake语法与练习

Cmake学习 1 语法特性介绍 基本语法格式&#xff1a;指令(参数 1 参数 2...) 参数使用括弧括起参数之间使用空格或分号分开 指令是大小写无关的&#xff0c;参数和变量是大小写相关的 set(HELLO hello.cpp) add_executable(hello main.cpp hello.cpp) ADD_EXECUTABLE(hello ma…...

Java(119):ExcelUtil工具类(org.apache.poi读取和写入Excel)

ExcelUtil工具类(XSSFWorkbook读取和写入Excel),入参和出参都是:List<Map<String,Object>> 一、读取Excel testdata.xlsx 1、new XSSFWorkbook对象 File file = new File(filePath); FileInputStream fis = new FileInputStream(file);…...

Kong处理web服务跨域

前言 好久没写文章了&#xff0c;大概有半年多了&#xff0c;这半年故事太多&#xff0c;本文写不下&#xff0c;就写写文章标题问题&#xff01; 问题描述 关于跨域的本质问题我这里不过多介绍&#xff0c;详细请看历史文章 跨域产生的原因以及常见的解决方案。 我这边是新…...

Kotlin学习——kt里的作用域函数scope function,let,run,with,apply,also

Kotlin 是一门现代但已成熟的编程语言&#xff0c;旨在让开发人员更幸福快乐。 它简洁、安全、可与 Java 及其他语言互操作&#xff0c;并提供了多种方式在多个平台间复用代码&#xff0c;以实现高效编程。 https://play.kotlinlang.org/byExample/01_introduction/02_Functio…...

informer辅助笔记:utils/timefeatures.py

定义了一套与时间特征相关的类和函数&#xff0c;旨在从时间序列数据中提取有用的时间特征&#xff0c;以支持各种时间序列分析和预测任务 from typing import Listimport numpy as np import pandas as pd from pandas.tseries import offsets from pandas.tseries.frequenc…...

[Verilog语法]:===和!==运算符使用注意事项

[Verilog语法]&#xff1a;和!运算符使用注意事项 1&#xff0c; 和 !运算符使用注意事项2&#xff0c;3&#xff0c; 1&#xff0c; 和 !运算符使用注意事项 参考文献&#xff1a; 1&#xff0c;[SystemVerilog语法拾遗] 和!运算符使用注意事项 2&#xff0c; 3&#xff0c;...

mybatis 高并发查询性能问题

场景&#xff1a; 使用Mybatis &#xff08;3.5.10&#xff09;SelectProvider注解执行动态sql 在高并发查询时 QPS 很低 问题复现 mybatis 配置 &#xff08;getOfflineConfigSqlTemplate 该方法返回的是动态sql &#xff09; 压测结果 观察线程阻塞情况 此时的QPS 在 …...

我在Vscode学OpenCV 图像处理一(阈值处理、形态学操作【连通性,腐蚀和膨胀,开闭运算,礼帽和黑帽,内核】)

文章目录 一、阈值处理1.1 OpenCV 提供了函数 cv2.threshold()和函数 cv2.adaptiveThreshold()&#xff0c;用于实现阈值处理1.1.1. cv2.threshold()&#xff1a;(1)在函数cv2.threshold()中&#xff0c;参数threshold_type用于指定阈值处理的方式。它有以下几种可选的阈值类型…...

Yolov8实现瓶盖正反面检测

一、模型介绍 模型基于 yolov8n数据集采用SKU-110k&#xff0c;这数据集太大了十几个 G&#xff0c;所以只训练了 10 轮左右就拿来微调了 基于原木数据微调&#xff1a;训练 200 轮的效果 10 轮SKU-110k 20 轮原木 200 轮瓶盖正反面 微调模型下载地址https://wwxd.lanzouu.co…...