Contains 判断字符串是否包含子串
package main
import (
"fmt"
"strings"
)
func main() {
src := "It's a cat."
fmt.Println(strings.Contains(src, "It's"))
fmt.Println(strings.ContainsRune(src, 'C')) //判断字符串s是否包含utf-8码值r
fmt.Println(strings.ContainsRune(src, 83))
fmt.Println(strings.ContainsAny(src, "ABC ")) // 判断字符串s是否包含字符串chars中的任一字符
fmt.Println(strings.HasPrefix(src, "It's")) // 判断s是否有前缀字符串prefix
fmt.Println(strings.HasSuffix(src, "It's")) // 判断s是否有后缀字符串suffix
}
判断相等&子串计数
package main
import (
"fmt"
"strings"
)
func main() {
src := "It's a cat."
// 判断相等
fmt.Println(src == "It's a cat.")
fmt.Println(strings.EqualFold(src, "it's a cat.")) // 判断两个utf-8编码字符串(将unicode大写、小写、标题三种格式字符视为相同)是否相同
// 子串计数
fmt.Println(strings.Count("srcit's srca cat.src", "src")) // 返回字符串s中有几个不重复的sep子串
fmt.Println(strings.Count("five", "")) // 5
}
计算索引
package main
import (
"fmt"
"strings"
)
func main() {
fmt.Println(strings.Index("it's srca cat.src", "src")) // 子串sep在字符串s中第一次出现的位置,不存在则返回-1
fmt.Println(strings.IndexRune("it's srca cat.src", 's')) // unicode码值r在s中第一次出现的位置,不存在则返回-1
fmt.Println(strings.IndexByte("it's srca cat.src", 's')) // 字符c在s中第一次出现的位置,不存在则返回-1
fmt.Println(strings.IndexAny("it's srca cat.src", "ABC")) // 字符串chars中的任一utf-8码值在s中第一次出现的位置,如果不存在或者chars为空字符串则返回-1
fmt.Println(strings.IndexFunc("it's srca cat.src", func(c rune) bool {
if c >= 'A' && c <= 'C' {
return true
} else {
return false
}
})) // s中第一个满足函数f的位置i(该处的utf-8码值r满足f(r)==true),不存在则返回-1
fmt.Println(strings.LastIndex("it's srca cat.src", "src"))
fmt.Println(strings.IndexAny("it's srca cat.src", "ABC"))
fmt.Println(strings.LastIndexFunc("it's srca cat.src", func(c rune) bool {
if c >= 'A' && c <= 'C' {
return true
} else {
return false
}
}))
}
大小写转换
package main
import (
"fmt"
"strings"
"unicode"
)
func main() {
var sc unicode.SpecialCase
fmt.Println(strings.Title("it's srca cat.src")) // 返回s中每个单词的首字母都改为标题格式的字符串拷贝
fmt.Println(strings.ToTitle("it's srca cat.src")) // 返回将所有字母都转为对应的标题版本的拷贝
fmt.Println(strings.ToLower("it's srca cat.src"))
fmt.Println(strings.ToLowerSpecial(sc, "it's srca cat.src"))
fmt.Println(strings.ToUpper("it's srca cat.src"))
fmt.Println(strings.ToUpperSpecial(sc, "it's srca cat.src"))
}
字符串拆分&拼接
package main
import (
"fmt"
"strings"
"unicode"
)
func main() {
//字符串拆分
fmt.Println(strings.Split("it'ssrcacat.src", "s"))
fmt.Println(strings.SplitN("it'ssrcacat.src", "s", 2))
fmt.Println(strings.SplitAfter("it'ssrcacat.src", "s"))
fmt.Println(strings.SplitAfterN("it'ssrcacat.src", "s", 2))
fmt.Println(strings.Fields("it's src cat src ")) //返回将字符串按照空白(unicode.IsSpace确定,可以是一到多个连续的空白字符)分割的多个字符串。如果字符串全部是空白或者是空字符串的话,会返回空切片
f := func(c rune) bool {
return !unicode.IsLetter(c) && !unicode.IsNumber(c)
}
fmt.Println(strings.FieldsFunc("it's src cat src ", f)) //类似Fields,但使用函数f来确定分割符(满足f的unicode码值)。如果字符串全部是分隔符或者是空字符串的话,会返回空切片
//字符串拼接
fmt.Println(strings.Join([]string{"foo", "bar", "baz"}, ", ")) //将一系列字符串连接为一个字符串,之间用sep来分隔
fmt.Println(strings.Repeat("test", 5)) //返回count个s串联的字符串
}
字符串替换
package main
import (
"fmt"
"strings"
)
func main() {
fmt.Println(strings.Replace("foo, bar, baz", ", ", " ", 1)) //返回将s中前n个不重叠old子串都替换为new的新字符串,如果n<0会替换所有old子串。
fmt.Println(strings.Replace("foo, bar, baz", ", ", " ", -1))
fmt.Println(strings.Map(func(r rune) rune {
switch {
case r >= 'A' && r <= 'Z':
return 'A' + (r-'A'+13)%26
case r >= 'a' && r <= 'z':
return 'a' + (r-'a'+13)%26
}
return r
}, "test")) // 将s的每一个unicode码值r都替换为mapping(r),返回这些新码值组成的字符串拷贝。如果mapping返回一个负值,将会丢弃该码值而不会被替换。(返回值中对应位置将没有码值)
}
trim 去除首尾字符
package main
import (
"fmt"
"strings"
)
func main() {
src := "It's a cat."
fmt.Println(strings.Trim(src, ".It"))
fmt.Println(strings.TrimSpace(src))
fmt.Println(strings.TrimLeft(src, ".It"))
fmt.Println(strings.TrimRight(src, ".It"))
fmt.Println(strings.TrimPrefix(src, "It's"))
fmt.Println(strings.TrimSuffix(src, "It's"))
fmt.Println(strings.TrimFunc(src, func(c rune) bool {
if (c >= 'a' && c <= 'z') || c >= 'A' && c <= 'Z' {
return true
} else {
return false
}
}))
fmt.Println(strings.TrimRightFunc(src, func(c rune) bool {
if (c >= 'a' && c <= 'z') || c >= 'A' && c <= 'Z' {
return true
} else {
return false
}
}))
fmt.Println(strings.TrimLeftFunc(src, func(c rune) bool {
if (c >= 'a' && c <= 'z') || c >= 'A' && c <= 'Z' {
return true
} else {
return false
}
}))
}
NewReader
package main
import (
"bytes"
"fmt"
"strings"
)
func main() {
s := "\n\n\n\n菜鸟教程(runoob.com) \n\n\n 我的第一个标题
\n 我的第一个段落。
\n\n"
nr := strings.NewReader(s)
// 获取字符串大小
fmt.Println(nr.Size()) //194
// 读取一个字节,byte类型
fmt.Println(nr.ReadByte()) // 60
//获取以读指针到字符串结尾的byte长度
fmt.Println(nr.Len()) // 193
fmt.Println(nr.UnreadByte()) //
fmt.Println(nr.Len()) // 194
// 读取一个字节,rune类型
fmt.Println(nr.ReadRune()) // 60 1
fmt.Println(nr.Len()) // 193
fmt.Println(nr.UnreadRune()) //
fmt.Println(nr.Len()) // 194
// func (r *Reader) Seek(offset int64, whence int) (int64, error)
//重定位读指针
fmt.Println(nr.Seek(100, 0)) // 100
fmt.Println(nr.Len()) // 94
// func (r *Reader) ReadAt(b []byte, off int64) (n int, err error)
//从起始位置偏移off的长度读取字节,不影响读指针
readContent := make([]byte, 100)
fmt.Println(nr.ReadAt(readContent, 50)) // 100
fmt.Println(bytes.NewBuffer(readContent).String()) // ">\n菜鸟教程(runoob.com) \n\n\n 我的第一个标题
\n
fmt.Println(nr.Len()) // 94
// func (r *Reader) WriteTo(w io.Writer) (n int64, err error)
//从起始位置偏移off的长度读取字节,不影响读指针
buf := bytes.NewBuffer(nil) // 创建 bytes.Buffer 对象,它实现了 io.Writer 接口
fmt.Println(nr.WriteTo(buf)) // 94
}
NewReplacer
package main
import (
"bytes"
"fmt"
"strings"
)
func main() {
// 使用提供的多组old、new字符串对创建并返回一个*Replacer。替换是依次进行的,匹配时不会重叠
// func NewReplacer(oldnew ...string) *Replacer
r := strings.NewReplacer("<", "<", ">", ">")
// Replace返回s的所有替换进行完后的拷贝。
// func (r *Replacer) Replace(s string) string
fmt.Println(r.Replace("This is HTML!")) // This is <b>HTML</b>!
// WriteString向w中写入s的所有替换进行完后的拷贝。
// func (r *Replacer) WriteString(w io.Writer, s string) (n int, err error)
buf := bytes.NewBuffer(nil) // 创建 bytes.Buffer 对象,它实现了 io.Writer 接口
s := "<"
fmt.Println(r.WriteString(buf, s)) // 4
fmt.Println(buf) // <
}