go strconv 包

本文详细介绍了Go语言中strconv包的使用,包括Atoi、Itoa、Parse系列和Format系列函数,用于实现字符串与基本数据类型的相互转换。还提到了其他辅助函数如isPrint和CanBackquote,以及Append系列函数,帮助开发者在编程中更方便地处理数据类型的转换。
摘要由CSDN通过智能技术生成

go strconv 包

介绍

go 语言不支持进行隐式的类型转换,只能手动去执行显性转换操作

转换数据类型的方式很简单。

valueOfTypeB = typeB(valueOfTypeA)

例如:

// 浮点数
a := 5.0

// 转换为int类型
b := int(a)

Go允许在底层结构相同的两个类型之间互转。例如:

// MyInt类型的底层是int类型
type MyInt int

// a的类型为MyInt,底层是int
var a MyInt = 5

// 将a(MyInt)转换为int,b现在是int类型
b := int(5)

// 将b(int)转换为MyInt,c现在是MyInt类型
c := MyInt(b)

但注意:

  1. 不是所有数据类型都能转换的,例如字母格式的string类型"lxx"转换为int肯定会失败
  2. 低精度转换为高精度时是安全的,高精度的值转换为低精度时会丢失精度。例如int32转换为int16,float32转换为int
  3. 这种简单的转换方式不能对int(float)和string进行互转,要跨大类型转换,可以使用strconv包提供的函数

strconv 包使用详解

strconv包实现了基本数据类型与其字符串表示的转换,主要有以下常用函数: Atoi()Itoa()、parse系列、format系列、append系列。

更多函数请查看官方文档中文文档

2.1 string与int类型转换

这一组函数是我们平时编程中用的最多的。

2.1.1 Atoi()

Atoi()函数用于将字符串类型的整数转换为int类型,函数签名如下。

func Atoi(s string) (i int, err error)

如果传入的字符串参数无法转换为int类型,就会返回错误。

//var age ="19e"
var age ="19"
age1,err:=strconv.Atoi(age)
if err != nil {
    fmt.Println("转换出错")
    return
}else {
    fmt.Printf("类型是:%T,值是:%d",age1,age1)
}
2.1.2 Itoa()

Itoa()函数用于将int类型数据转换为对应的字符串表示,具体的函数签名如下。

func Itoa(i int) string

示例代码如下:

i := 999
s2 := strconv.Itoa(i)
fmt.Printf("类型是:%T 值是:%#v\n", s2, s2)
2.1.3 a解释

这是C语言遗留下的典故,C语言中没有string类型而是用字符数组(array)表示字符串,所以a指的是array即字符串,在go中字符串也是以byte类型切片和rune类型切片存储的

2.2 Parse系列函数

Parse类函数用于转换字符串为给定类型的值:ParseBool()ParseFloat()ParseInt()ParseUint()

2.2.1 ParseBool()
func ParseBool(str string) (value bool, err error)

返回字符串表示的 bool 值。它只接受值为1、0、t、f、T、F、true、false、True、False、TRUE、FALSE的字符串;否则返回错误。

2.2.2 ParseInt()
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

2.2.3 ParseUnit()
func ParseUint(s string, base int, bitSize int) (n uint64, err error)

ParseUint类似ParseInt但不接受正负号,用于无符号整型。

2.2.4 ParseFloat()

func ParseFloat(s string, bitSize int) (f float64, err error)

解析一个表示浮点数的字符串并返回其值。

如果s合乎语法规则,函数会返回最为接近s表示值的一个浮点数

bitSize指定了期望的接收类型,32是float32(返回值可以不改变精确值的赋值给float32),64是float64;

返回值err是*NumErr类型的,语法有误的,err.Error=ErrSyntax;结果超出表示范围的,返回值f为±Inf,err.Error= ErrRange。

2.2.5 代码示例
// 1 字符串转布尔(1、0、t、f、T、F、true、false、True、False、TRUE、FALSE)
res,_:=strconv.ParseBool("false")
res,_:=strconv.ParseBool("f")
fmt.Printf("类型为:%T,值为:%t",res,res)

// 2 字符串转int
// base:2到36,指进制
// bitSize:0、8、16、32、64 分别代表 int、int8、int16、int32、int64
res,_:=strconv.ParseInt("999",10,64)
res,_:=strconv.ParseInt("999",10,32)
fmt.Printf("类型为:%T,值为:%d",res,res)

// 3 ParseUnit()
// bitSize指定为几,都返回uint64,再转成相应类型不会丢失
res,_:=strconv.ParseUint("99",10,64)
fmt.Printf("类型为:%T,值为:%d",res,res)

// 4 ParseFloat()
res,_:=strconv.ParseFloat("8.99",64)
fmt.Printf("类型为:%T,值为:%f",res,res)

这些函数都有两个返回值,第一个返回值是转换后的值,第二个返回值为转化失败的错误

2.3 Format系列函数

Format系列函数实现了将给定类型数据格式化为string类型数据的功能。

2.3.1 FormatBool()
func FormatBool(b bool) string

根据b的值返回true或false

2.3.2 FormatInt()
func FormatInt(i int64, base int) string

返回i的base进制的字符串表示。base 必须在2到36之间,结果中会使用小写字母’a’到’z’表示大于10的数字。

2.3.3 FormatUint()
func FormatUint(i uint64, base int) string

FormatInt的无符号整数版本。

2.3.4 FormatFloat()
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。

2.3.5 代码示例
res := strconv.FormatBool(true)
res := strconv.FormatFloat(3.14150, 'f', -1, 64) // prec为-1表示使用最少数量表示,最后的0就省略了,如果prec为1,表示小数点后1位
res := strconv.FormatInt(-2, 16)
res := strconv.FormatUint(17, 16)
fmt.Printf("类型为:%T,值为:%s",res,res)

2.4 其他

2.4.1 isPrint()
func IsPrint(r rune) bool

返回一个字符是否是可打印的,和unicode.IsPrint一样,r必须是:字母(广义)、数字、标点、符号、ASCII空格。

2.4.2 CanBackquote()
func CanBackquote(s string) bool

返回字符串s是否可以不被修改的表示为一个单行的、没有空格和tab之外控制字符的反引号字符串。

2.4.3 Append系列

Append类的函数和Format类的函数工作方式类似,只不过是将转换后的结果追加到一个slice中

将其他类型转换成字符串后append到一个slice中:AppendBool()AppendFloat()AppendInt()AppendUint()

	b := []byte("99的十进制是:")
	// 将转换为10进制的string,追加到slice中
	b = strconv.AppendInt(b, 99, 10)
	fmt.Println(string(b))
2.4.4 代码
	//一个字符是否是可打印的
	res:=strconv.IsPrint('n')  // true 可打印
	res:=strconv.IsPrint('\n')  // false  不可打印

	//是否可以不被修改的表示为一个单行的、没有空格和tab之外控制字符的反引号字符串
	res:=strconv.CanBackquote(`lxx is Nb`) // true
	res:=strconv.CanBackquote(`lxx is
Nb`) // false :因为带回车
	fmt.Println(res)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

go&Python

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值