bytes中常用函数的使用:

package main;

import (
"bytes"
"fmt"
"unicode"
) //bytes包中实现了大量对[]byte操作的函数和两个最主要的Reader和Buffer两个结构 func main() {
str := "aBcD";
//转为小写
fmt.Println(string(bytes.ToLower([]byte(str))));
//转为大写
fmt.Println(string(bytes.ToUpper([]byte(str))));
//转为标题,
fmt.Println(string(bytes.ToTitle([]byte(str)))); //自定义映射表
mycase := unicode.SpecialCase{
unicode.CaseRange{
//1,1表示替换规则只影响1到1之间的字符
1,
1,
[unicode.MaxCase]rune{
//大写转换
'壹' - 1,
//小写转换
'一' - 1,
//标题转换
'小' - 1,
},
},
unicode.CaseRange{
2,
2,
[unicode.MaxCase]rune{
'贰' - 2,
'二' - 2,
'中' - 2,
},
},
unicode.CaseRange{
3,
3,
[unicode.MaxCase]rune{
'叁' - 3,
'三' - 3,
'大' - 3,
},
},
};
//使用映射表将[]byte中字符修改为小写
data := bytes.ToLowerSpecial(
mycase,
[]byte{1, 2, 3},
)
fmt.Println(string(data));
//使用映射表将[]byte中字符修改为大写
data = bytes.ToUpperSpecial(
mycase,
[]byte{1, 2, 3},
);
fmt.Println(string(data));
//使用映射表将[]byte中字符修改为标题
data = bytes.ToTitleSpecial(
mycase,
[]byte{1, 2, 3},
);
fmt.Println(string(data)); //将[]byte中单词首字符修改为Title并返回
fmt.Println(string(bytes.Title([]byte("abc def")))); //比较两个[]byte,
// a < b 返回 -1
// a == b 返回 0
// b > b 返回 1
fmt.Println(bytes.Compare([]byte("a"), []byte("b"))); //比较两个[]byte是否相等
fmt.Println(bytes.Equal([]byte("abc"), []byte("abc"))); //比较两个[]byte是否相等,忽略大写,小写,标题
fmt.Println(bytes.EqualFold([]byte("ABC"), []byte("abc"))); //去掉[]byte两边包含在cutset中的字符
fmt.Println(string(bytes.Trim([]byte(" abc "), " "))); //去掉左边包含在cutset中的字符
fmt.Println(string(bytes.TrimLeft([]byte(" abc "), " "))); //去掉右边包含在cutset中的字符
fmt.Println(string(bytes.TrimRight([]byte(" abc "), " "))); //去掉两边空白字符
fmt.Println(string(bytes.TrimSpace([]byte(" abc ")))); //去掉前缀
fmt.Println(string(bytes.TrimPrefix([]byte("tb_user"), []byte("tb_")))); //去掉后缀
fmt.Println(string(bytes.TrimSuffix([]byte("user_idx"), []byte("_idx")))); //以sep为分隔符,切分为多个[]byte
tmp := bytes.Split([]byte("ab cd ef"), []byte(" "));
for _, v := range tmp {
fmt.Println(string(v));
} //分割最多n个子切片,超出n的部分将不进行切分
tmp = bytes.SplitN([]byte("ab cd ef"), []byte(" "), 2);
for _, v := range tmp {
fmt.Println(string(v));
} //以sep为分隔符,切分为多个[]byte,结果包含分隔符,在子串尾部
tmp = bytes.SplitAfter([]byte("ab,cd,ef"), []byte(","));
for _, v := range tmp {
fmt.Println(string(v));
} //分割最多n个子切片,超出n的部分将不进行切分
tmp = bytes.SplitAfterN([]byte("ab,cd,ef"), []byte(","), 2);
for _, v := range tmp {
fmt.Println(string(v));
} //以空白字符切分
tmp = bytes.Fields([]byte("a b c d"));
for _, v := range tmp {
fmt.Println(string(v));
} //以符合函数的字符作为分隔符来切分
tmp = bytes.FieldsFunc([]byte("asbscsd"), func(r rune) bool {
if r == rune('s') {
return true;
}
return false;
});
for _, v := range tmp {
fmt.Println(string(v));
} //以sep为连接符,拼接[][]byte
fmt.Println(string(bytes.Join(
[][]byte{
[]byte("aa"),
[]byte("bb"),
[]byte("cc"),
},
[]byte("-"),
))); //重复[]byte,Count次
fmt.Println(string(bytes.Repeat([]byte("abc"), 3))); //判断是否有前缀
fmt.Println(bytes.HasPrefix([]byte("is_true"), []byte("is_"))); //判断是否有后缀
fmt.Println(bytes.HasSuffix([]byte("chk_on"), []byte("_on"))); //判断是否包含某个[]byte
fmt.Println(bytes.Contains([]byte("i am jack"), []byte("jack"))); //判断是否包含某个rune
fmt.Println(bytes.ContainsRune([]byte("i from 中国"), rune('中'))); //查找sep在参数一中第一次出现的位置,找不到返回-1
fmt.Println(bytes.Index([]byte("abcabc"), []byte("a")));
fmt.Println(bytes.IndexByte([]byte("cba"), 'a'));
fmt.Println(bytes.IndexRune([]byte("i from 中国"), rune('中'))); //查找chars中任意一个字符在参数一中出现的位置,找不到返回-1
fmt.Println(bytes.IndexAny([]byte("hello world"), "xy")); //功能同上,只不过查找最后一次出现的位置
fmt.Println(bytes.LastIndex([]byte("abcabc"), []byte("a")));
fmt.Println(bytes.LastIndexByte([]byte("cba"), 'a'));
fmt.Println(bytes.LastIndexAny([]byte("hello world"), "xy")); //获取sep中在参数一中出现的次数
fmt.Println(bytes.Count([]byte("a|b|c"), []byte("|"))); //将参数一中前n个old替换成new,n小于0则全部替换。
fmt.Println(string(
bytes.Replace(
[]byte("i am jack"),
[]byte("i am"),
[]byte("我是"),
-1,
),
)); //将[]byte中的字符替换为函数的返回值,如果返回值为负数,则丢弃访字符。
fmt.Println(string(
bytes.Map(
func(r rune) rune {
if r == 'a' {
return 'A';
} else if r == 'c' {
return -1;
}
return r;
},
[]byte("abcd"),
),
)); //将[]byte转换为[]rune
fmt.Println(string(bytes.Runes([]byte("我是谁"))));
}

bytes中Reader和Buffer的使用:

package main;

import (
"bytes"
"fmt"
) //bytes中Reader和Buffer两个结构的使用 func useReader() {
data := "abcdefghijk";
//通过[]byte创建Reader
re := bytes.NewReader([]byte(data));
//返回未读取部分的长度
fmt.Println("re len : ", re.Len());
//返回底层数据总长度
fmt.Println("re size : ", re.Size()); buf := make([]byte, 2);
for {
//读取数据
n, err := re.Read(buf);
if err != nil {
break;
}
fmt.Println(string(buf[:n]));
}; //设置偏移量,因为上面的操作已经修改了读取位置等信息
re.Seek(0, 0);
for {
//一个字节一个字节的读
b, err := re.ReadByte();
if err != nil {
break;
}
fmt.Println(string(b));
} re.Seek(0, 0);
off := int64(0);
for {
//指定偏移量读取
n, err := re.ReadAt(buf, off);
if err != nil {
break;
}
off += int64(n);
fmt.Println(off, string(buf[:n]));
}
} func useBuffer() {
data := "123456789";
//通过[]byte创建一个Buffer
bf := bytes.NewBuffer([]byte(data)); //Len()返回未读取的数据长度
fmt.Println("bf len : ", bf.Len()); //Cap()缓存容量
fmt.Println("bf cap : ", bf.Cap()); //Bytes()返回未读取的数据切片
bys := bf.Bytes();
for _, v := range bys {
fmt.Print(string(v) + " ");
}
fmt.Println(); //Next()返回未读取部分前n字节数据的切片
for i := 0; i < 10; i++ {
tmp := bf.Next(1);
fmt.Print(string(tmp) + " ");
}
fmt.Println();
//再次Next,返回[]byte,说明没有未读取的
fmt.Println(bf.Next(1)); //重设缓冲,丢弃全部内容
bf.Reset(); //通过string创建Buffer
bf2 := bytes.NewBufferString(data);
//读取第一个 delim 及其之前的内容,返回遇到的错误
line, _ := bf2.ReadBytes('3');
fmt.Println(string(line));
//效果同上,返回string
line2, _ := bf2.ReadString('7');
fmt.Println(line2); //创建一个空Buffer
bf3 := bytes.Buffer{};
//自动增加缓存容量,保证有n字节剩余空间
bf3.Grow(16);
//写入rune编码,返回写入的字节数和错误。
n, _ := bf3.WriteRune(rune('中'));
fmt.Println("bf3 write ", n);
n, _ = bf3.WriteString("国人");
fmt.Println("bf3 write ", n);
//返回未读取的字符串
fmt.Println(bf3.String());
//将数据长度截断到n字节
bf3.Truncate(6);
fmt.Println(bf3.String());
} func main() {
//防止main中代码过多,我新建两个函数单独写
useReader();
useBuffer();
}

  

golang语言中bytes包的常用函数,Reader和Buffer的使用的更多相关文章

  1. golang语言中os包的学习与使用(文件,目录,进程的操作)

    os中一些常用函数的使用: package main; import ( "os" "fmt" "time" "strings&q ...

  2. go语言中regexp包中的函数和方法

    // regexp.go ------------------------------------------------------------ // 判断在 b 中能否找到正则表达式 patter ...

  3. php 中函数获取可变参数的方法, 这个语法有点像 golang 语言中的

    原文呢:http://php.net/manual/en/functions.arguments.php#functions.arguments.type-declaration.strict Onl ...

  4. C语言中malloc()和calloc()c函数用法

    C语言中malloc()和calloc()c函数用法   函数malloc()和calloc()都可以用来动态分配内存空间,但两者稍有区别. malloc()函数有一个参数,即要分配的内存空间的大小: ...

  5. golang语言中sync/atomic包的学习与使用

    package main; import ( "sync/atomic" "fmt" "sync" ) //atomic包提供了底层的原子级 ...

  6. golang语言中os/signal包的学习与使用

    package main; import ( "os" "os/signal" "fmt" ) //signal包中提供了两个函数 //No ...

  7. golang语言中os/exec包的学习与使用

    package main; import ( "os/exec" "fmt" "io/ioutil" "bytes" ) ...

  8. go语言中strings包中的Trim函数的作用是什么

    答:Trim函数原型如下: func Trim(s string, cutset string) string 去掉字符串s中首部以及尾部与字符串cutset中每个相匹配的字符,如: s=" ...

  9. C语言中math.h中常用的函数

    1.绝对值 ①函数原型: int abs(int x); 函数功能: 求整数x的绝对值 int number=-1234; abs(number); ②函数原型:double fabs(double ...

随机推荐

  1. 强制停止ORACLE数据库

    操作环境 SuSE+Oracle11gR2 适用场景 shutdown immediate停止数据库失败 操作命令 1.kill掉oracle实例相关进程 2.清除oracle占用的共享内存段 ipc ...

  2. gitbash上使用tree

    gitbash上使用tree vscode从cmd设置gitbash之后,想在使用windows下的tree命令发现运行不了,有两种解决方案. 1,在gitbash上cmd //c tree,就等同c ...

  3. 使用firefox插件httperrequest,模拟发送及接收Json请求 【转】

    转自[http://blog.csdn.net/feixue1232/article/details/8535212] 目标:使用httpreques\Json-Handle\tcpdump\wire ...

  4. Hadoop分布式HA的安装部署

    Hadoop分布式HA的安装部署 前言 单机版的Hadoop环境只有一个namenode,一般namenode出现问题,整个系统也就无法使用,所以高可用主要指的是namenode的高可用,即存在两个n ...

  5. git 分支合并develop 重新拉取

    1.本地包 zb-local 上传到对应的线上分支 zb-online cd 进入本地所在文件夹,然后执行下面三项 git add . git commit -m '修改' git push   或者 ...

  6. tensorflow 高级api使用分布式之配置

    """Constructor. Sets the properties `cluster_spec`, `is_chief`, `master` (if `None` i ...

  7. python遇到的错误

    今天学习文件遇到这个错误. 这是在 text_files\vvvv.txt  之间加一个\ 就可以了,变成  text_files\\vvvv.txt,运行成功

  8. jQuery写省级联动列表,创造二维数组,以及如何存/调用二维数组中的数据

    jQuery写省级联动列表,创造二维数组来存放数据,然后通过each来遍历调用,通过creatTxtNode创建文本节点,通过createElement创建标签option,在通过append将文本写 ...

  9. Mybatis批量更新和插入

    <update id="updateOrInsert"> <foreach collection="list" index="ind ...

  10. 【C++】operator new/new operator/placement new之间的区别

    new operator new operator即是c++中的关键字new.比如A* = new A; 中的new就是new operator. 它执行了三个步骤: 1. 分配内存空间 事实上,分配 ...