参考https://studygolang.com/pkgdoc

导入方式:

import "strings"

strings包实现了用于操作字符的简单函数。

常用的几个函数:

func Contains

func Contains(s, substr string) bool

判断字符串s是否包含子串substr。

举例:

package main
import(
"fmt"
"strings" ) func main() {
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
}

func Index

func Index(s, sep string) int

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

举例:

package main
import(
"fmt"
"strings" ) func main() {
fmt.Println(strings.Index("chicken", "ken")) //
fmt.Println(strings.Index("chicken", "dmr")) //-1
}

func Join

func Join(a []string, sep string) string

将一系列字符串连接为一个字符串,之间用sep来分隔。

举例:

package main
import(
"fmt"
"strings" ) func main() {
s := []string{"foo", "bar", "baz"}
fmt.Println(strings.Join(s, ", "))//foo, bar, baz
}

func Repeat

func Repeat(s string, count int) string

返回count个s串联的字符串。

举例:

package main
import(
"fmt"
"strings" ) func main() {
fmt.Println("ba" + strings.Repeat("na", )) //banana
}

func Replace

func Replace(s, old, new string, n int) string

返回将s中前n个不重叠old子串都替换为new的新字符串,如果n<0会替换所有old子串。

举例:

package main
import(
"fmt"
"strings" ) func main() {
fmt.Println(strings.Replace("oink oink oink", "k", "ky", )) //oinky oinky oink
fmt.Println(strings.Replace("oink oink oink", "oink", "moo", -)) //moo moo moo
}

func Split

func Split(s, sep string) []string

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

举例:

package main
import(
"fmt"
"strings" ) 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")) //[""]
}

func Trim

func Trim(s string, cutset string) string

返回将s前后端所有cutset包含的utf-8码值都去掉的字符串。

举例:

package main
import(
"fmt"
"strings" ) func main() {
fmt.Printf("[%q]\n", strings.Trim(" !!! Achtung! Achtung! !!! ", "! ")) //["Achtung! Achtung"]
}

func Fields

func Fields(s string) []string

返回将字符串按照空白(unicode.IsSpace确定,可以是一到多个连续的空白字符)分割的多个字符串。如果字符串全部是空白或者是空字符串的话,会返回空切片。

举例:

package main
import(
"fmt"
"strings" ) func main() {
fmt.Printf("Fields are: %q\n", strings.Fields(" foo bar baz ")) //Fields are: ["foo" "bar" "baz"]
}

)type Reader

type Reader struct {
s string
i int64 // current reading index
prevRune int // index of previous rune; or < 0

Reader类型通过从一个字符串读取数据,实现了io.Reader、io.Seeker、io.ReaderAt、io.WriterTo、io.ByteScanner、io.RuneScanner接口。

实现源码:

1> func NewReader

func NewReader(s string) *Reader

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

该初始化源码:

func NewReader(s string) *Reader { return &Reader{s, 0, -1} }

举例:

package main
import(
"fmt"
"io"
"strings"
"os"
)
func main() {
reader := strings.NewReader("test reader's usage")
buf := make([]byte, 4) //生成一个能够存放4 bytes数据的数组
for {//无限循环直至有错或数据读取完返回EOF
count, err := reader.Read(buf)//后面读取的内容会覆盖前面的buf的内容
if err != nil {
if err == io.EOF {
fmt.Println("EOF : ", count)
break
}
fmt.Println(err)
os.Exit(1)
}
fmt.Println(count, string(buf[:count]))
}
}

返回:

userdeMBP:src user$ go run test.go
4 test
4 rea
4 der'
4 s us
3 age
EOF :

2》func (*Reader) Len

func (r *Reader) Len() int

Len返回r包含的字符串还没有被读取的部分,即当前文件指针之后的内容

3》func (*Reader) Read

func (r *Reader) Read(b []byte) (n int, err error)

4》func (*Reader) ReadByte

func (r *Reader) ReadByte() (b byte, err error)

5》func (*Reader) UnreadByte

func (r *Reader) UnreadByte() error

6》func (*Reader) ReadRune

func (r *Reader) ReadRune() (ch rune, size int, err error)

7》func (*Reader) UnreadRune

func (r *Reader) UnreadRune() error

8》func (*Reader) ReadAt

func (r *Reader) ReadAt(b []byte, off int64) (n int, err error)

9》func (*Reader) WriteTo

func (r *Reader) WriteTo(w io.Writer) (n int64, err error)

WriteTo实现了io.WriterTo接口。

举例:

package main
import(
"fmt"
"strings"
"log"
"os"
)
func main() {
fmt.Println("1 - test Read")
reader := strings.NewReader("test strings's NewReader() and the usage of its function\n")
len := reader.Len()
fmt.Printf("1 before - the length of the part have not beed read : %d\n", len)
data := make([]byte, 8)
number, err := reader.Read(data)
if err != nil {
log.Fatal(err)
}
len = reader.Len()
fmt.Printf("1 after - the length of the part have not beed read : %d\n", len)
fmt.Println(string(data[:number])) fmt.Println("2 - test ReadByte")
for i := 0; i < 3; i++ {
readbyte, err := reader.ReadByte()//从当前文件指针向后读取一个byte的内容
if err != nil {
log.Fatal(err)
}
fmt.Print(readbyte, " ")
}
fmt.Println() len = reader.Len()
fmt.Printf("2 after - the length of the part have not beed read : %d\n", len) fmt.Println("3 - test UnreadByte") //就相当于撤销之前的一次ReadByte()操作,文件指针向前移一位
err = reader.UnreadByte()
if err != nil {
log.Fatal(err)
} len = reader.Len()
fmt.Printf("3 after - the length of the part have not beed read : %d\n", len) fmt.Println("4 - test ReadAt")
number1, err := reader.ReadAt(data, 11)
if err != nil {
log.Fatal(err)
}
len = reader.Len()
fmt.Printf("4 after - the length of the part have not beed read : %d\n", len)
fmt.Println(string(data[:number1])) fmt.Println("5 - test ReadRune")
for i := 0; i < 3; i++ {
readrune, _, err := reader.ReadRune()//从当前文件指针向后读取一个rune的内容
if err != nil {
log.Fatal(err)
}
fmt.Print(readrune, " ")
// fmt.Print(readrune)
}
fmt.Println() len = reader.Len()
fmt.Printf("5 after - the length of the part have not beed read : %d\n", len) fmt.Println("6 - test UnreadRune")
err = reader.UnreadRune() //就相当于撤销之前的一次ReadByte()操作,文件指针向前移一位
if err != nil {
log.Fatal(err)
}
len = reader.Len()
fmt.Printf("6 after - the length of the part have not beed read : %d\n", len) fmt.Println("test WriterTo")
number3, err := reader.WriteTo(os.Stdout)//从当前指针开始将文件内容输出到os.Stdout,即标准输出中
if err != nil {
log.Fatal(err)
}
fmt.Println(number3)
}

返回:

userdeMBP:src user$ go run test.go
1 - test Read
1 before - the length of the part have not beed read : 57
1 after - the length of the part have not beed read : 49
test str
2 - test ReadByte
105 110 103 //即ing
2 after - the length of the part have not beed read : 46
3 - test UnreadByte
3 after - the length of the part have not beed read : 47
4 - test ReadAt
4 after - the length of the part have not beed read : 47
s's NewR
5 - test ReadRune
103 115 39 //即gs'
5 after - the length of the part have not beed read : 44
6 - test UnreadRune
6 after - the length of the part have not beed read : 45
test WriterTo
's NewReader() and the usage of its function

未完待续

go标准库的学习-strings-字符串操作的更多相关文章

  1. Python3标准库:string通用字符串操作

    1. string:通用字符串操作 string模块在很早的Python版本中就有了.以前这个模块中提供的很多函数已经移植为str对象的方法,不过这个模块仍保留了很多有用的常量和类来处理str对象. ...

  2. go标准库的学习-net/http

    参考:https://studygolang.com/pkgdoc 概念解释: request:用户请求的信息,用来解析用户的请求信息,包括post.get.cookie.url等信息 respons ...

  3. go标准库的学习-database/sql

    参考:https://studygolang.com/pkgdoc 导入方式: import "database/sql" sql包提供了保证SQL或类SQL数据库的泛用接口. 使 ...

  4. go标准库的学习-crypto/md5

    参考:https://studygolang.com/pkgdoc 导入方式: import "crypto/md5" md5包实现了MD5哈希算法,参见RFC 1321. Con ...

  5. go标准库的学习-crypto/sha1

    参考:https://studygolang.com/pkgdoc 导入方式: import "crypto/sha1" sha1包实现了SHA1哈希算法,参见RFC 3174. ...

  6. go标准库的学习-crypto/sha256

    参考:https://studygolang.com/pkgdoc 导入方式: import "crypto/sha256" sha256包实现了SHA224和SHA256哈希算法 ...

  7. go标准库的学习-path/filepath

    参考https://studygolang.com/pkgdoc 标准库path中有的该path/filepath库中都有,所以一般都使用path/filepath 导入方式: import &quo ...

  8. go标准库的学习-io

    参考https://studygolang.com/pkgdoc 导入方式: import "io" o包提供了对I/O原语的基本接口.本包的基本任务是包装这些原语已有的实现(如o ...

  9. go标准库的学习-bufio

    参考https://studygolang.com/pkgdoc 导入方式: import "bufio" bufio包实现了有缓冲的I/O.它包装一个io.Reader或io.W ...

  10. python 标准库基础学习之开发工具部分1学习

    #2个标准库模块放一起学习,这样减少占用地方和空间#标准库之compileall字节编译源文件import compileall,re,sys#作用是查找到python文件,并把它们编译成字节码表示, ...

随机推荐

  1. Spring MVC 学习总结(十)——Spring+Spring MVC+MyBatis框架集成(IntelliJ IDEA SSM集成)

    与SSH(Struts/Spring/Hibernate/)一样,Spring+SpringMVC+MyBatis也有一个简称SSM,Spring实现业务对象管理,Spring MVC负责请求的转发和 ...

  2. mysql中的游标使用

    1.游标的作用及属性 游标的作用就是用于对查询数据库所返回的记录进行遍历,以便进行相应的操作:游标有下面这些属性: a.游标是只读的,也就是不能更新它: b.游标是不能滚动的,也就是只能在一个方向上进 ...

  3. asp.net mvc之自定义WebViewPage

    采用Razor引擎的View文件最终都会编译成一个WebViewPage类型, 通过自定义WebViewPage,添加相应的属性和方法,你可以很方便的在View里调用, 自定义WebViewPage只 ...

  4. jQuery基础教程

    1.使用$()函数 $()函数其实是创建了一个jQuery对象. 这个函数接受CSS选择符作为参数,充当一个工厂, 返回包含页面中对应元素的jQuery对象. 所有能在样式表中使用的选择符都可以传给这 ...

  5. (2)Jquery1.8.3快速入门_checkbox全选取消部分选中

    1. jquery示例功能: checkbox多选框 全选 .全不选. 选择部分. 源码 : <!DOCTYPE html> <html> <head> <m ...

  6. C#设计模式——简单工厂模式、工厂模式和抽象工厂模式

    一:简单工厂模式 1:描述:简单工厂模式是由一个工厂对象根据接收到的消息决定要创建哪一个类的对象事例. 2:优点:工厂类中有相关逻辑判断,可以根据需要动态创建相关的对象事例,而客户端只需要告诉工厂类创 ...

  7. SQL Server中的数据类型

    参考 SQL Server 2012编程入门经典(第4版) SQL Server 自带的数据类型 整型: 货币 近似小数 日期/时间 特殊数字 字符 Unicode 二进制 其他

  8. WEB前端面试2014阿里旺旺

    NO1.下图绿色区域的宽度为100%,其中有三个矩形,第一个矩形的宽度是200px,第二个和第三个矩形的宽度相等.请使用css3中的功能实现它们的布局. 已知HTML结构是: <div clas ...

  9. HTML中令人惊喜的全局属性

    1.accesskey 属性 : 规定激活元素的快捷键. 浏览器支持:几乎所有浏览器均 accesskey 属性,除了 Opera. 定义和用法 accesskey 属性规定激活(使元素获得焦点)元素 ...

  10. JMeter 集合点设置之Synchronizing Timer的使用

    集合点设置之Synchronizing Timer的使用 by:授客 QQ:1033553122 1.布局设置 注: 1) 说明: 名称:自定义名称 Number of Simulated Users ...