其实我也不明白是什么让我坚持下来一点一点的分析pkg包,但是分析的时候我感觉还是很高兴的!今天我们继续strings包
(1)func Index(s, sep string) int 这个函数是查找字符串,然后返回当前的位置,输入的都是string类型,然后int的位置信息
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.Index("widuu", "i")) //1
		fmt.Println(strings.Index("widuu", "u")) //3
	}

(2)func IndexAny(s, chars string) int 这个函数是一样的查找,字符串第一次出现的位置,如果不存在就返回-1
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.IndexAny("widuu", "u")) //3
	}

(3)func IndexByte(s string, c byte) int,这个函数功能还是查找第一次粗线的位置,只不过这次C是byte类型的,查找到返回位置,找不到返回-1
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.IndexByte("hello xiaowei", 'x')) //6
	}

(4)func IndexRune(s string, r rune) int,还是查找位置,只不过这次是rune类型的
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.IndexRune("widuu", rune('w'))) //0
	}

(5)func IndexFunc(s string, f func(rune) bool) int这个函数大家一看就知道了,是通过类型的转换来用函数查找位置,我们来代码看下哈
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.IndexFunc("nihaoma", split)) //3
	}
	
	func split(r rune) bool {
		if r == 'a' {
			return true
		}
		return false
	}

(6)func Join(a []string, sep string) string,这个跟php中的implode差不多,这个函数是将一个[]string的切片通过分隔符,分割成一个字符串
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		s := []string{"hello", "word", "xiaowei"}
		fmt.Println(strings.Join(s, "-")) //	hello-word-xiaowei
	}

(7)func LastIndex(s, sep string) int 看到这个大家可能也明白了查找的是最后出现的位置,正好跟index相反
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.LastIndex("widuu", "u")) //	4
	}

(8)func LastIndexAny(s, chars string) int这个跟indexAny正好相反,也是查找最后一个
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.LastIndexAny("widuu", "u")) //	4
	}

(9)func LastIndexFunc(s string, f func(rune) bool) int,这个和IndexFunc正好相反,通过函数查找最后一个位置
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.LastIndexFunc("nihaoma", split)) //6
	}
	
	func split(r rune) bool {
		if r == 'a' {
			return true
		}
		return false
	}

(10)func Map(mapping func(rune) rune, s string) string,该函数以此读取s中的字符,传入mapping函数,然后返回的字符链接起来,说白了就是字符串的每一个字符通过mapping函数的处理,最后返回处理好的字符串,如果处理不正确,那么就抛弃该字符
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.Map(func(r rune) rune {
			if r == 'a' {
				return 'i'
			}
			return r
		}, "hello waduu")) //hello widuu
	}

(11)func Repeat(s string, count int) string,这个函数就是输出几个重复的字符串,count代表重复的次数
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.Repeat("widuu", 3)) //widuuwiduuwiduu
	}

(12)func Replace(s, old, new string, n int) string,这个函数是把一个字符串中的字符替换成你定义的字符,n是替换的数值,如果n<0就是替换全部,返回的知识一个副本
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		s := "widuuweb"
		fmt.Println(strings.Replace(s, "u", "a", 1))  //widauweb
		fmt.Println(strings.Replace(s, "u", "a", -1)) //widaaweb
		fmt.Println(s)                                //widuuweb
	}

(13)func Split(s, sep string) []string,有join就有Split这个就是把字符串按照指定的分隔符切割成slice
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.Split("a,b,c,d,e", ",")) //[a b c d e]
	}

(15)func SplitAfter(s, sep string) []string,这个函数是在前边的切割完成之后再后边在加上sep分割符
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.SplitAfter("a,b,c,d", ",")) //[a, b, c, d]
	}

(16)func SplitAfterN(s, sep string, n int) []string该函数s根据sep分割,返回分割之后子字符串的slice,和split一样,只是返回的子字符串保留sep,如果sep为空,那么每一个字符都分割
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.SplitAfterN("a,b,c,d,r", ",", 4)) //["a," "b," "c," "d,r"]
		fmt.Println(strings.SplitAfterN("a,b,c,d,r", ",", 5)) //["a," "b," "c," "d," "r"]
	}

(17)func SplitN(s, sep string, n int) []string,这个是切割字符串的时候自己定义长度,如果sep为空,那么每一个字符都分割
	import (
		"fmt"
		"strings"
	)
	
	func main() {
		fmt.Println(strings.SplitN("a,b,c", ",", 2)) //[a b,c]
	}
每天只讲一点golang的标准库,方便大家学习和使用,更多的时候去理解标准库,大家多动手,如果你喜欢请继续关注我们 [caption id="attachment_902" align="alignnone" width="300"]Golang标准库http/url Values Golang标准库[/caption]

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论
立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部