1 简介

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

2 string <-> int

(1) Atoi()

Atoi()函数用于将字符串类型的整数转换为int类型

  1. s1 := "100"
  2. i1, err := strconv.Atoi(s1)
  3. if err != nil {
  4. fmt.Println("can't convert to int")
  5. } else {
  6. fmt.Printf("type:%T value:%#v\n", i1, i1) //type:int value:100
  7. }

(2) Itoa()

Itoa()函数用于将int类型数据转换为对应的字符串表示,

  1. i2 := 200
  2. s2 := strconv.Itoa(i2)
  3. fmt.Printf("type:%T value:%#v\n", s2, s2) //type:string value:"200"

3 string -> bool, float, int

(1) ParseBool()

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

  1. func ParseBool(str string) (value bool, err error)

(2) ParseInt()

返回字符串表示的整数值,接受正负号。

  • base指定进制(2到36),如果base为0,则会从字符串前置判断,”0x”是16进制,”0o”是8进制,否则是10进制;
  • bitSize指定结果必须能无溢出赋值的整数类型,0、8、16、32、64 分别代表 int、int8、int16、int32、int64;

返回的err是*NumErr类型的,如果语法有误,err.Error = ErrSyntax;如果结果超出类型范围err.Error = ErrRange。

  1. func ParseInt(s string, base int, bitSize int) (i int64, err error)

(3) ParseUint()

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

  1. func ParseUint(s string, base int, bitSize int) (n uint64, err error)

(4) ParseFloat()

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

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

4 bool, float, int -> string

(1) Formatbool

  1. func FormatBool(b bool) string

(2) FormatInt()

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

  1. func FormatInt(i int64, base int) string

(3) FormatUint()

  1. func FormatUint(i uint64, base int) string

(4) FormatFloat()

  1. 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。