欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

golang中之strconv包的具体使用方法

程序员文章站 2022-04-28 17:22:43
在编程过程中,我们常常需要用到字符串与其它类型的转换,strconv包可以帮我们实现此功能。 1.string -> int 使用方法:func atoi(s strin...

在编程过程中,我们常常需要用到字符串与其它类型的转换,strconv包可以帮我们实现此功能。

1.string -> int

使用方法:func atoi(s string) (i int, err error)

测试代码:

func atoi(s string) (i int, err error)
numstr := "999"
num, err := strconv.atoi(numstr)
if err != nil {
  fmt.println("can't convert to int")
} else {
  fmt.printf("type:%t value:%#v\n", num, num)
}

输出:type:int value:999

另外还可以用:

func parseint(s string, base int, bitsize int) (i int64, err error) 

func parseuint(s string, base int, bitsize int) (n uint64, err error)

base指定进制(2到36),如果base为0,则会从字符串前置判断,”0x”是16进制,”0”是8进制,否则是10进制;

bitsize指定结果必须能无溢出赋值的整数类型,0、8、16、32、64 分别代表 int、int8、int16、int32、int64;

2. int -> string

使用方法:func itoa(i int) string

测试代码:

func itoa(i int) string
num := 200
numstr := strconv.itoa(num)
fmt.printf("type:%t value:%#v\n", numstr, numstr)

输出:type:string value:"200"

3. string->bool

  • 使用方法: func parsebool(str string) (bool, error)
  • 当str为:1,t,t,true,true,true中的一种时为真值 
  • 当str为:0,f,f,false,false,false中的一种时为假值
  • 测试代码
fmt.println(strconv.parsebool("t"))
fmt.println(strconv.parsebool("true"))
fmt.println(strconv.parsebool("true"))
fmt.println(strconv.parsebool("true"))
fmt.println(strconv.parsebool("0"))
fmt.println(strconv.parsebool("f"))

4.string->float

使用方法: func parsefloat(s string, bitsize int) (f float64, err error)

bitsize:32或64 对应系统的位数

测试代码

strf := "250.56"
str, err := strconv.parsefloat(strf, 64)
if err != nil {
  fmt.println(err)
}
fmt.printf("type:%t value:%#v\n", str, str)

输出:type:float64 value:250.56

5. float -> string

使用方法: 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。

测试代码:

num := 250.56
str := strconv.formatfloat(num, 'f', 4,64)
fmt.printf("type:%t value:%#v\n", str, str)

输出:type:string value:"250.5600"

当然,以上类型转string的话,可以直接用 fmt.sprintf 实现。

举个例子:

num := 250.56
str := fmt.sprintf("%.2f", num)
fmt.printf("type:%t value:%#v\n", str, str)

输出:type:string value:"250.56"

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。