golangのstrconvパッケージ
2824 ワード
プログラミングの過程で、文字列と他のタイプの変換をよく必要とします.strconvパッケージはこの機能を実現するのに役立ちます.
1.string -> int使用方法: テストコード:
出力:type:int value:999はさらに、 を用いることができる.
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使用方法: テストコード:
出力:type:string value:“200”
3. string->boolの使用方法: テストコード
4.string->float使用方法: テストコード
出力:type:float 64 value:25.56
5. float -> string使用方法:
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は最小数であるが必要な数で表される.テストコード:
出力:type:string value:“250.5600”
もちろん、以上のタイプの回転stringは、
出力:type:string value:“250.56”
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”