1.strconv包
strconv包实现了基本数据类型与其字符串表示的转换,主要有以下常用函数:Atoi(),Itia(),parse系列,format系列,append系列。
1.1string与int类型转换
1.1.1Atoi()
Atoi()函数用于将字符串类型的整数转换为int类型
func Atoi(s string) (i int, err error)
如果传入的字符串参数无法转换为Int类型,就会返回错误。
package main
import (
"fmt"
"strconv"
)
func main() {
s1 := "100"
i1,err := strconv.Atoi(s1)
if err != nil{
fmt.Println("can not convert to int")
}else{
fmt.Printf("type:%T value:%#v\n",i1,i1)
}
}
结果:
type:int value:100
Process finished with exit code 0
1.1.2Itoa()
Itoa()函数用于将int累心数据转换为对应的字符串表示。
func Itoa(i int) string
package main
import (
"fmt"
"strconv"
)
func main() {
i1 := 100
s1 := strconv.Itoa(i1)
fmt.Printf("type:%T value:%#v\n",s1,s1)
}
结果:
type:string value:"100"
Process finished with exit code 0
a的典故:
【扩展阅读】这是C语言遗留下的典故。C语言中没有string类型而是用字符数组(array)表示字符串,所以Itoa对很多C系的程序员很好理解。
1.2Parse系列函数
Parse系列函数用于转换字符串为给定类型的值:ParseBool(),ParseFloat(),ParseInt(),ParseUint()。
1.2.1ParseBool()
func ParseBool(str string) (value bool, err error)
返回字符串表示的bool值。它接收1,0,t,f,T,F,true,True,False,TRUE,FALSE;否则返回错误。
1.2.2ParseInt()
func ParseInt(s string, base int, bitSize int) (i int64, err error)
返回字符串表示的整数值,接受正负号。
base:指定进制(2到36),如果base为0,则会从字符串前置判断,"0x"是16进制,"0"是8进制,否则是10进制;
bitSize:指定结果必须能无溢出赋值的整数类型,0,8,16,32,64分别代表int,int8,int16,int32,int64;
err:是*NumErr类型的,如果语法有误,err.Error=ErrSyntax;如果超出类型范围err.Error=ErrRange。
1.2.3ParseUint()
func ParseUint(s string, base int, bitSize int) (n uint64, err error)
ParseUint类似ParseInt但不接受正负号,用于无符号整型。
1.2.4ParseFloat()
func ParseFloat(s string, bitSize int) (f float64, err error)
解析一个表示浮点数的字符串并返回其值。
如果s符合语法规则,函数会返回最为接近s表示值得一个浮点数(使用IEEE754规范舍入)。
bitSize:指定了期望的接收类型,32是float32(返回值可以不改变精确值的赋值给float32),64是float64;
err:是*NumErr类型的,语法有误的,err.Error=ErrSyntax;结果超出表示范围的,返回值f为±Inf,err.Error= ErrRange。
1.2.5示例
package main
import (
"fmt"
"strconv"
)
func main() {
b, _ := strconv.ParseBool("true")
fmt.Println(b)
f, _ := strconv.ParseFloat("3.1415", 64)
fmt.Println(f)
i, _ := strconv.ParseInt("-2", 10, 64)
fmt.Println(i)
u, _ := strconv.ParseUint("2", 10, 64)
fmt.Println(u)
}
结果:
true
3.1415
-2
2
Process finished with exit code 0
1.3Format系列函数
Format系列函数实现了将给定类型数据格式化为string类型数据的功能。
1.3.1FormatBool()
func FormatBool(b bool) string
根据b的值返回”true”或”false”。
1.3.2FormatInt()
func FormatInt(i int64, base int) string
返回i的base进制的字符串表示。base 必须在2到36之间,结果中会使用小写字母’a’到’z’表示大于10的数字。
1.3.3FormatUint()
func FormatUint(i uint64, base int) string
是FormatInt的无符号整数版本。
1.3.4FormatFloat()
func FormatFloat(f float64, fmt byte, prec, bitSize int) string
bitSize表示f的来源类型(32:float32、64:float64),会据此进行舍入。
fmt表示格式:’f’(-ddd.dddd)、’b’(-ddddp±ddd,指数为二进制)、’e’(-d.dddde±dd,十进制指数)、’E’(-d.ddddE±dd,十进制指数)、’g’(指数很大时用’e’格式,否则’f’格式)、’G’(指数很大时用’E’格式,否则’f’格式)。
prec控制精度(排除指数部分):对’f’、’e’、’E’,它表示小数点后的数字个数;对’g’、’G’,它控制总的数字个数。如果prec 为-1,则代表使用最少数量的、但又必需的数字来表示f。
1.3.5示例
package main
import (
"fmt"
"strconv"
)
func main() {
s1 := strconv.FormatBool(true)
s2 := strconv.FormatFloat(3.1415, 'E', -1, 64)
s3 := strconv.FormatInt(-2, 16)
s4 := strconv.FormatUint(2, 16)
fmt.Printf("Type:%T value:%#v\n",s1,s1)
fmt.Printf("Type:%T value:%#v\n",s2,s2)
fmt.Printf("Type:%T value:%#v\n",s3,s3)
fmt.Printf("Type:%T value:%#v\n",s4,s4)
}
结果:
Type:string value:"true"
Type:string value:"3.1415E+00"
Type:string value:"-2"
Type:string value:"2"
Process finished with exit code 0
1.4其他
1.4.1isPrint()
func IsPrint(r rune) bool
返回一个字符是否是可打印的,和unicode.IsPrint一样,r必须是:字母(广义)、数字、标点、符号、ASCII空格。
1.4.2CanBackquote()
func CanBackquote(s string) bool
返回字符串s是否可以不被修改的表示为一个单行的、没有空格和tab之外控制字符的反引号字符串。
其他用法可以查看官方文档:https://golang.org/pkg/strconv/
有疑问加站长微信联系(非本文作者)