本博客采用创作共用版权协议, 要求署名、非商业用途和保持一致. 转载本博客文章必须也遵循 署名-非商业用途-保持一致 的创作共用协议.
本文形式为, 给出一个函数接口, 然后匹配相关example. 关注函数主要集中在 strings
和 strconv
// Compare比较字符串的速度比字符串内建的比较要快 funcCompare(a, bstring)int
fmt.Println(strings.Compare(string("hello"),string("haha")))// 1 fmt.Println(strings.Compare(string("hello"),string("world")))// -1 fmt.Println(strings.Compare(string("hello"),string("helloworld")))// -1 fmt.Println(strings.Compare(string("hello"),string("hello")))//0
// 判断给定字符串s中是否包含子串substr, 找到返回true, 找不到返回false funcContains(s, substrstring)bool // 在字符串s中查找sep所在的位置, 返回位置值, 找不到返回-1 funcIndex(s, sepstring)int // 统计给定子串sep的出现次数, sep为空时, 返回1 + 字符串的长度 funcCount(s, sepstring)int
fmt.Println(strings.Contains("seafood","foo"))// true fmt.Println(strings.Contains("seafood","bar"))// false fmt.Println(strings.Contains("seafood",""))// true fmt.Println(strings.Contains("",""))// true fmt.Println(strings.Index("chicken","ken"))// 4 fmt.Println(strings.Index("chicken","dmr"))// -1 fmt.Println(strings.Count("cheeseeee","ee"))// 3 fmt.Println(strings.Count("five",""))// 5
// 重复s字符串count次, 最后返回新生成的重复的字符串 func Repeat(sstring,countint)string
fmt.Println("ba"+ strings.Repeat("na",2))// banana
// 在s字符串中, 把old字符串替换为new字符串,n表示替换的次数,小于0表示全部替换 funcReplace(s, old,newstring, nint)string
fmt.Println(strings.Replace("oink oink oink","k","ky",2))// oinky oinky oink fmt.Println(strings.Replace("oink oink oink","oink","moo", -1))// moo moo moo
// 删除在s字符串的头部和尾部中由cutset指定的字符, 并返回删除后的字符串 funcTrim(sstring, cutsetstring)string // 删除首尾的空格
// 删除首部和尾部的 ! 和空格 fmt.Printf("%q/n", strings.Trim(" !!! Achtung! Achtung! !!! ","! ")) //"Achtung! Achtung" fmt.Printf("%q/n", strings.TrimSpace(" /t/n a lone gopher /n/t/r/n")) //"a lone gopher"
// 给定字符串转换为英文标题的首字母大写的格式(不能正确处理unicode标点) funcTitle(sstring)string // 所有字母转换为小写 funcToLower(sstring)string // 所有字母转换为大写 funcToUpper(sstring)string
fmt.Println(strings.Title("her royal highness"))// Her Royal Highness fmt.Println(strings.ToLower("Gopher123"))// gopher123 fmt.Println(strings.ToUpper("Gopher"))// GOPHER
前缀和后缀的判断均为大小写敏感
// 判断字符串是否包含前缀prefix funcHasPrefix(s, prefixstring)bool // 判断字符串是否包含后缀suffix, funcHasSuffix(s, suffixstring)bool
fmt.Println(strings.HasPrefix("Gopher","Go"))// true fmt.Println(strings.HasPrefix("Gopher","go"))// false fmt.Println(strings.HasPrefix("Gopher","C"))// false fmt.Println(strings.HasPrefix("Gopher",""))// true fmt.Println(strings.HasSuffix("Amigo","go"))// true fmt.Println(strings.HasSuffix("Amigo","O"))// false fmt.Println(strings.HasSuffix("Amigo","Ami"))// false fmt.Println(strings.HasSuffix("Amigo",""))// true
// 把字符串按照sep进行分割, 返回slice(类似于python中的split) funcSplit(s, sepstring) []string // 去除字符串s中的空格符, 并按照空格(可以是一个或者多个空格)分割字符串, 返回slice funcFields(sstring) []string // 当字符串中字符c满足函数f(c)时, 就进行字符串s的分割 funcFieldsFunc(sstring, ffunc(rune)bool) []string
func main() { fmt.Printf("%q/n", strings.Split("a,b,c",",")) // ["a""b""c"] fmt.Printf("%q/n", strings.Split("a man a plan a canal panama","a ")) // ["""man ""plan ""canal panama"] fmt.Printf("%q/n", strings.Split(" xyz ","")) // [" ""x""y""z"" "] fmt.Printf("%q/n", strings.Split("","Bernardo O'Higgins")) // [""] fmt.Printf("%q/n", strings.Split("1 og.txt"," ")) } // ["1""og.txt"] fmt.Printf("Fields are: %q/n", strings.Fields(" foo bar baz ")) //Fieldsare: ["foo""bar""baz"] f := func(c rune) bool{ return!unicode.IsLetter(c) && !unicode.IsNumber(c) } // 表示按照非字母, 非数字来分割字符串 fmt.Printf("Fields are: %q/n", strings.FieldsFunc(" foo1;bar2,baz3...", f)) //Fieldsare: ["foo1""bar2""baz3"]
+=
操作符, 直接将多个字符串拼接. 最直观的方法, 不过当数据量非常大时用这种拼接访求是非常低效的. 用字符串切片([]string)装载所有要拼接的字符串,最后使用strings.Join()
函数一次性将所有字符串拼接起来。在数据量非常大时,这种方法的效率也还可以的。 Buffer是一个实现了读写方法的可变大小的字节缓冲
),将所有的字符串都写入到一个Buffer变量中,最后再统一输出. // bytes.Buffer的方法, 将给定字符串追加(append)到Buffer func(b *Buffer) WriteString(sstring) (nint, err error) // 字符串拼接, 把slice通过给定的sep连接成一个字符串 funcJoin(a []string, sepstring)string
package main import ( "bytes" "fmt" "strings" "time" ) func main() { var buffer bytes.Buffer s := time.Now() fori :=0; i <100000; i++ { buffer.WriteString("test is here/n") } buffer.String() // 拼接结果 e := time.Now() fmt.Println("taked time is ", e.Sub(s).Seconds()) s = time.Now() str := "" fori :=0; i <100000; i++ { str += "test is here/n" } e = time.Now() fmt.Println("taked time is ", e.Sub(s).Seconds()) s = time.Now() var sl []string fori :=0; i <100000; i++ { sl = append(sl, "test is here/n") } strings.Join(sl, "") e = time.Now() fmt.Println("taked time is", e.Sub(s).Seconds()) }
taked timeis0.004145088 taked timeis13.78821647 taked timeis0.024005696
字符串转化的函数在 strconv
中
Append*
函数表示将给定的类型(如 bool, int
等)转换为字符串后, 添加在现有的字节数组中 []byte
Format*
函数将给定的类型变量转换为string返回 Parse*
函数将字符串转换为其他类型 // 字符串转整数 funcAtoi(sstring) (iint, err error) // 整数值换字符串 funcItoa(iint)string
str:= make([]byte,0,100) str= strconv.AppendInt(str,123,10)// 10用来表示进制, 此处为10进制 str= strconv.AppendBool(str,false) str= strconv.AppendQuote(str,"andrew") str= strconv.AppendQuoteRune(str,'刘') fmt.Println(string(str))// 123false"andrew"'刘' s := strconv.FormatBool(true) fmt.Printf("%T, %v/n", s, s)// string, true v := 3.1415926535 s32 := strconv.FormatFloat(v, 'E', -1,32) fmt.Printf("%T, %v/n", s32, s32)// string, 3.1415927E+00 s10 := strconv.FormatInt(-44,10) fmt.Printf("%T, %v/n", s10, s10)// string, -44 num := strconv.Itoa(1234) fmt.Printf("%T, %v/n", s, s)// int, 1023 fmt.Printf("%T, %v/n", num, num)// string, 1234