golangのstrconvパッケージ

2824 ワード

プログラミングの過程で、文字列と他のタイプの変換をよく必要とします.strconvパッケージはこの機能を実現するのに役立ちます.
1.string -> int
  • 使用方法: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
    ", 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の場合、文字列の前置から判断します.「0 x」は16進数、「0」は8進数、そうでない場合は10進数です.
    bitSizeは、結果がオーバーフロー付与されない整数タイプを指定し、0、8、16、32、64はint、int 8、int 16、int 32、int 64をそれぞれ表す.
    2. int -> string
  • 使用方法:func Itoa(i int) string
  • テストコード:
  • num := 200
    numStr := strconv.Itoa(num)
    fmt.Printf("type:%T value:%#v
    ", 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
    ", str, str)

    出力:type:float 64 value:25.56
    5. float -> string
  • 使用方法:func FormatFloat(f float64, fmt byte, prec, bitSize int) string bitSizeはfのソースタイプ(32:float 32、64:float 64)を表し、これに基づいて丸められます.

  • fmtは、フォーマットを表す:'f’(-ddd.dddddd)、'b’(-ddp±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
    ", str, str)

    出力:type:string value:“250.5600”
    もちろん、以上のタイプの回転stringは、fmt.Sprintfで直接実現できます.例を挙げます.
    num := 250.56
    str := fmt.Sprintf("%.2f", num)
    fmt.Printf("type:%T value:%#v
    ", str, str)

    出力:type:string value:“250.56”