golang中strings包用法

1.strings.Split
/ Split 以 sep 为分隔符,将 s 切分成多个子切片,结果中不包含 sep 本身
// 如果 sep 为空,则将 s 切分成 Unicode 字符列表。
// 如果 s 中没有 sep 子串,则将整个 s 作为 []string 的第一个元素返回

func Split(s, sep string) []string
func main() {
	s := "Hello, 世界! Hello!"
	ss := strings.Split(s, " ")
	fmt.Printf("%q\n", ss) // ["Hello," "世界!" "Hello!"]
	ss = strings.Split(s, ", ")
	fmt.Printf("%q\n", ss) // ["Hello" "世界! Hello!"]
	ss = strings.Split(s, "")
	fmt.Printf("%q\n", ss) // 单个字符列表
}

2.strings.SplitAfter
// SplitAfter 以 sep 为分隔符,将 s 切分成多个子切片,结果中包含 sep 本身
// 如果 sep 为空,则将 s 切分成 Unicode 字符列表。
// 如果 s 中没有 sep 子串,则将整个 s 作为 []string 的第一个元素返回

func SplitAfter(s, sep string) []string
func main() {
	s := "Hello, 世界! Hello!"
	ss := strings.SplitAfter(s, " ")
	fmt.Printf("%q\n", ss) // ["Hello, " "世界! " "Hello!"]
	ss = strings.SplitAfter(s, ", ")
	fmt.Printf("%q\n", ss) // ["Hello, " "世界! Hello!"]
	ss = strings.SplitAfter(s, "")
	fmt.Printf("%q\n", ss) // 单个字符列表
}

3. strings.Join
// Join 将 a 中的子串连接成一个单独的字符串,子串之间用 sep 分隔

func Join(a []string, sep string) string
func main() {
	ss := []string{"Monday", "Tuesday", "Wednesday"}
	s := strings.Join(ss, "|")
	fmt.Println(s)
}

4.trings.Repeat
// Repeat 将 count 个字符串 s 连接成一个新的字符串

func Repeat(s string, count int) string
func main() {
	s := "Hello!"
	rs := strings.Repeat(s, 3)
	fmt.Printf("%q\n", rs) // "Hello!Hello!Hello!"
}

// ToUpper 将 s 中的所有字符修改为其大写格式
// 对于非 ASCII 字符,它的大写格式需要查表转换
func ToUpper(s string) string

// ToLower 将 s 中的所有字符修改为其小写格式
// 对于非 ASCII 字符,它的小写格式需要查表转换
func ToLower(s string) string

// ToTitle 将 s 中的所有字符修改为其 Title 格式
// 大部分字符的 Title 格式就是其 Upper 格式
// 只有少数字符的 Title 格式是特殊字符
// 这里的 ToTitle 主要给 Title 函数调用

func ToTitle(s string) string
func main() {
	s := "heLLo worLd Abc"
	us := strings.ToUpper(s)
	ls := strings.ToLower(s)
	ts := strings.ToTitle(s)
	fmt.Printf("%q\n", us) // "HELLO WORLD ABC"
	fmt.Printf("%q\n", ls) // "hello world abc"
	fmt.Printf("%q\n", ts) // "HELLO WORLD ABC"
}

// 获取非 ASCII 字符的 Title 格式列表

func main() {
	for _, cr := range unicode.CaseRanges {
		// u := uint32(cr.Delta[unicode.UpperCase]) // 大写格式
		// l := uint32(cr.Delta[unicode.LowerCase]) // 小写格式
		t := uint32(cr.Delta[unicode.TitleCase]) // Title 格式
		// if t != 0 && t != u {
		if t != 0 {
			for i := cr.Lo; i <= cr.Hi; i++ {
				fmt.Printf("%c -> %c\n", i, i+t)
			}
		}
	}
}

// ToUpperSpecial 将 s 中的所有字符修改为其大写格式。
// 优先使用 _case 中的规则进行转换
func ToUpperSpecial(_case unicode.SpecialCase, s string) string

// ToLowerSpecial 将 s 中的所有字符修改为其小写格式。
// 优先使用 _case 中的规则进行转换
func ToLowerSpecial(_case unicode.SpecialCase, s string) string

// ToTitleSpecial 将 s 中的所有字符修改为其 Title 格式。
// 优先使用 _case 中的规则进行转换
func ToTitleSpecial(_case unicode.SpecialCase, s string) string

_case 规则说明,以下列语句为例:
unicode.CaseRange{‘A’, ‘Z’, [unicode.MaxCase]rune{3, -3, 0}}
·其中 ‘A’, ‘Z’ 表示此规则只影响 ‘A’ 到 ‘Z’ 之间的字符。
·其中 [unicode.MaxCase]rune 数组表示:
当使用 ToUpperSpecial 转换时,将字符的 Unicode 编码与第一个元素值(3)相加
当使用 ToLowerSpecial 转换时,将字符的 Unicode 编码与第二个元素值(-3)相加
当使用 ToTitleSpecial 转换时,将字符的 Unicode 编码与第三个元素值(0)相加

func main() {
	// 定义转换规则
	var _MyCase = unicode.SpecialCase{
		// 将半角逗号替换为全角逗号,ToTitle 不处理
		unicode.CaseRange{',', ',',
			[unicode.MaxCase]rune{',' - ',', ',' - ',', 0}},
		// 将半角句号替换为全角句号,ToTitle 不处理
		unicode.CaseRange{'.', '.',
			[unicode.MaxCase]rune{'。' - '.', '。' - '.', 0}},
		// 将 ABC 分别替换为全角的 ABC、abc,ToTitle 不处理
		unicode.CaseRange{'A', 'C',
			[unicode.MaxCase]rune{'A' - 'A', 'a' - 'A', 0}},
	}
	s := "ABCDEF,abcdef."
	us := strings.ToUpperSpecial(_MyCase, s)
	fmt.Printf("%q\n", us) // "ABCDEF,ABCDEF。"
	ls := strings.ToLowerSpecial(_MyCase, s)
	fmt.Printf("%q\n", ls) // "abcdef,abcdef。"
	ts := strings.ToTitleSpecial(_MyCase, s)
	fmt.Printf("%q\n", ts) // "ABCDEF,ABCDEF."
}

// Trim 将删除 s 首尾连续的包含在 cutset 中的字符

func Trim(s string, cutset string) string
func main() {
	s := " Hello 世界! "
	ts := strings.Trim(s, " Helo!")
	fmt.Printf("%q\n", ts) // "世界"
}

// TrimLeft 将删除 s 头部连续的包含在 cutset 中的字符

func TrimLeft(s string, cutset string) string
func main() {
	s := " Hello 世界! "
	ts := strings.TrimLeft(s, " Helo")
	fmt.Printf("%q\n", ts) // "世界! "
}

// TrimRight 将删除 s 尾部连续的包含在 cutset 中的字符

func TrimRight(s string, cutset string) string
func main() {
	s := " Hello 世界! "
	ts := strings.TrimRight(s, " 世界!")
	fmt.Printf("%q\n", ts) // " Hello"
}

// TrimSpace 将删除 s 首尾连续的的空白字符

func TrimSpace(s string) string
func main() {
	s := " Hello 世界! "
	ts := strings.TrimSpace(s)
	fmt.Printf("%q\n", ts) // "Hello 世界!"
}

// TrimPrefix 删除 s 头部的 prefix 字符串
// 如果 s 不是以 prefix 开头,则返回原始 s

func TrimPrefix(s, prefix string) string
func main() {
	s := "Hello 世界!"
	ts := strings.TrimPrefix(s, "Hello")
	fmt.Printf("%q\n", ts) // " 世界"
}

// TrimSuffix 删除 s 尾部的 suffix 字符串
// 如果 s 不是以 suffix 结尾,则返回原始 s

func TrimSuffix(s, suffix string) string
func main() {
	s := "Hello 世界!!!!!"
	ts := strings.TrimSuffix(s, "!!!!")
	fmt.Printf("%q\n", ts) // " 世界"
}

注:TrimSuffix只是去掉s字符串结尾的suffix字符串,只是去掉1次,而TrimRight是一直去掉s字符串右边的字符串,只要有响应的字符串就去掉,是一个多次的过程,这也是二者的本质区别.
14.
// Replace 返回 s 的副本,并将副本中的 old 字符串替换为 new 字符串
// 替换次数为 n 次,如果 n 为 -1,则全部替换
// 如果 old 为空,则在副本的每个字符之间都插入一个 new

func Replace(s, old, new string, n int) string
func main() {
	s := "Hello 世界!"
	s = strings.Replace(s, " ", ",", -1)
	fmt.Println(s)
	s = strings.Replace(s, "", "|", -1)
	fmt.Println(s)
}

详细请参考:
https://studygolang.com/articles/5769

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Go ,你可以使用 `==` 运算符来判断两个字符串是否完全匹配。例如: ``` s1 := "Hello, World" s2 := "Hello, World" if s1 == s2 { fmt.Println("The strings are equal.") } else { fmt.Println("The strings are not equal.") } ``` 上面的代码会输出 "The strings are equal.",因为两个字符串完全匹配。 注意,这种方法只能用于比较两个字符串的完全匹配,如果你想要进行模糊匹配(例如,忽略大小写,或者只匹配字符串的一部分),你可以使用 Go 的内置函数 `strings.EqualFold()` 或 `strings.Contains()`。 例如: ``` s1 := "Hello, World" s2 := "hello, world" if strings.EqualFold(s1, s2) { fmt.Println("The strings are equal (ignoring case).") } else { fmt.Println("The strings are not equal.") } if strings.Contains(s1, "World") { fmt.Println("s1 contains the string 'World'.") } ``` 上面的代码会输出 "The strings are equal (ignoring case)." 和 "s1 contains the string 'World'."。 ### 回答2: golangstrings提供了多种方法来处理字符串,其括字符串的完全匹配。 要判断一个字符串是否与另一个字符串完全匹配,可以使用strings的Equal方法。这个方法接收两个字符串作为参数,并返回一个布尔值,表示这两个字符串是否完全相同。 下面是一个使用Equal方法判断字符串是否完全匹配的示例代码: ```go package main import ( "fmt" "strings" ) func main() { str1 := "Hello" str2 := "Hello" if strings.EqualFold(str1, str2) { fmt.Println("字符串完全匹配") } else { fmt.Println("字符串不完全匹配") } } ``` 在这个示例,我们定义了两个字符串变量str1和str2,并将它们分别赋值为"Hello"。然后,我们使用Equal方法判断这两个字符串是否完全匹配。如果它们完全相同,我们就打印"字符串完全匹配",否则打印"字符串不完全匹配"。 在实际应用,字符串的完全匹配可以用于判断用户输入是否与特定字符串相等,或者判断两个字符串是否相同等场景。使用strings的Equal方法,我们可以方便地实现这一功能。 ### 回答3: 在Golang,可以使用strings的函数来进行字符串的完全匹配。具体而言,可以使用strings的EqualFold函数来判断两个字符串是否在不区分大小写的情况下完全匹配。 EqualFold函数的用法是:strings.EqualFold(str1, str2),其str1和str2分别是要比较的两个字符串。如果两个字符串在不区分大小写的情况下完全匹配,该函数将返回true,否则将返回false。 除了EqualFold函数之外,还可以使用等号直接比较两个字符串,比如str1 == str2。这种方式只有当两个字符串完全相同(括大小写)时才返回true,否则返回false。 需要注意的是,strings提供的函数只能进行简单的字符串比较,不能进行更为复杂的匹配操作。如果需要进行更复杂的匹配,可能需要使用正则表达式或其他相关的工具。 总之,在Golang,可以使用strings.EqualFold函数或直接使用等号来判断两个字符串是否完全匹配。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值