Go基礎系列:數據類型轉換(strconv包)

Go不會對數據進行隱式的類型轉換,只能手動去執行轉換操做。golang

簡單的轉換操做

轉換數據類型的方式很簡單。安全

valueOfTypeB = typeB(valueOfTypeA)

例如:app

// 浮點數
a := 5.0

// 轉換爲int類型
b := int(a)

Go容許在底層結構相同的兩個類型之間互轉。例如:函數

// IT類型的底層是int類型
type IT int

// a的類型爲IT,底層是int
var a IT = 5

// 將a(IT)轉換爲int,b如今是int類型
b := int(5)

// 將b(int)轉換爲IT,c如今是IT類型
c := IT(b)

但注意:ui

  1. 不是全部數據類型都能轉換的,例如字母格式的string類型"abcd"轉換爲int確定會失敗
  2. 低精度轉換爲高精度時是安全的,高精度的值轉換爲低精度時會丟失精度。例如int32轉換爲int16,float32轉換爲int
  3. 這種簡單的轉換方式不能對int(float)和string進行互轉,要跨大類型轉換,可使用strconv包提供的函數

strconv

strconv包提供了字符串與簡單數據類型之間的類型轉換功能。能夠將簡單類型轉換爲字符串,也能夠將字符串轉換爲其它簡單類型。code

這個包裏提供了不少函數,大概分爲幾類:orm

  • 字符串轉int:Atoi()
  • int轉字符串: Itoa()
  • ParseTP類函數將string轉換爲TP類型:ParseBool()、ParseFloat()、ParseInt()、ParseUint()。由於string轉其它類型可能會失敗,因此這些函數都有第二個返回值表示是否轉換成功
  • FormatTP類函數將其它類型轉string:FormatBool()、FormatFloat()、FormatInt()、FormatUint()
  • AppendTP類函數用於將TP轉換成字符串後append到一個slice中:AppendBool()、AppendFloat()、AppendInt()、AppendUint()

還有其餘一些基本用不上的函數,見官方手冊:go doc strconv或者https://golang.org/pkg/strconv/。字符串

當有些類型沒法轉換時,將報錯,返回的錯誤是strconv包中自行定義的error類型。有兩種錯誤:string

var ErrRange = errors.New("value out of range")
var ErrSyntax = errors.New("invalid syntax")

例如,使用Atoi("a")將"a"轉換爲int類型,天然是不成功的。若是print輸出err信息,將顯示:it

strconv.Atoi: parsing "a": invalid syntax

string和int的轉換

最多見的是字符串和int之間的轉換:

1.int轉換爲字符串:Itoa()

// Itoa(): int -> string
println("a" + strconv.Itoa(32))  // a32

2.string轉換爲int:Atoi()

func Atoi(s string) (int, error)

因爲string可能沒法轉換爲int,因此這個函數有兩個返回值:第一個返回值是轉換成int的值,第二個返回值判斷是否轉換成功。

// Atoi(): string -> int
i,_ := strconv.Atoi("3")
println(3 + i)   // 6

// Atoi()轉換失敗
i,err := strconv.Atoi("a")
if err != nil {
    println("converted failed")
}

Parse類函數

Parse類函數用於轉換字符串爲給定類型的值:ParseBool()、ParseFloat()、ParseInt()、ParseUint()。

因爲字符串轉換爲其它類型可能會失敗,因此這些函數都有兩個返回值,第一個返回值保存轉換後的值,第二個返回值判斷是否轉換成功。

b, err := strconv.ParseBool("true")
f, err := strconv.ParseFloat("3.1415", 64)
i, err := strconv.ParseInt("-42", 10, 64)
u, err := strconv.ParseUint("42", 10, 64)

ParseFloat()只能接收float64類型的浮點數。

ParseInt()和ParseUint()有3個參數:

func ParseInt(s string, base int, bitSize int) (i int64, err error)
func ParseUint(s string, base int, bitSize int) (uint64, error)

bitSize參數表示轉換爲何位的int/uint,有效值爲0、八、1六、3二、64。當bitSize=0的時候,表示轉換爲int或uint類型。例如bitSize=8表示轉換後的值的類型爲int8或uint8。

base參數表示以什麼進制的方式去解析給定的字符串,有效值爲0、2-36。當base=0的時候,表示根據string的前綴來判斷以什麼進制去解析:0x開頭的以16進制的方式去解析,0開頭的以8進制方式去解析,其它的以10進制方式解析。

以10進制方式解析"-42",保存爲int64類型:

i, _ := strconv.ParseInt("-42", 10, 64)

以5進制方式解析"23",保存爲int64類型:

i, _ := strconv.ParseInt("23", 5, 64)
println(i)    // 13

由於5進制的時候,23表示進位了2次,再加3,因此對應的十進制數爲5*2+3=13

以16進制解析23,保存爲int64類型:

i, _ := strconv.ParseInt("23", 16, 64)
println(i)    // 35

由於16進制的時候,23表示進位了2次,再加3,因此對應的十進制數爲16*2+3=35

以15進制解析23,保存爲int64類型:

i, _ := strconv.ParseInt("23", 15, 64)
println(i)    // 33

由於15進制的時候,23表示進位了2次,再加3,因此對應的十進制數爲15*2+3=33

Format類函數

將給定類型格式化爲string類型:FormatBool()、FormatFloat()、FormatInt()、FormatUint()。

s := strconv.FormatBool(true)
s := strconv.FormatFloat(3.1415, 'E', -1, 64)
s := strconv.FormatInt(-42, 16)
s := strconv.FormatUint(42, 16)

FormatInt()和FormatUint()有兩個參數:

func FormatInt(i int64, base int) string
func FormatUint(i uint64, base int) string

第二個參數base指定將第一個參數轉換爲多少進制,有效值爲2<=base<=36。當指定的進制位大於10的時候,超出10的數值以a-z字母表示。例如16進制時,10-15的數字分別使用a-f表示,17進制時,10-16的數值分別使用a-g表示。

例如:FormatInt(-42, 16)表示將-42轉換爲16進制數,轉換的結果爲-2a。

FormatFloat()參數衆多:

func FormatFloat(f float64, fmt byte, prec, bitSize int) string

bitSize表示f的來源類型(32:float3二、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。

Append類函數

AppendTP類函數用於將TP轉換成字符串後append到一個slice中:AppendBool()、AppendFloat()、AppendInt()、AppendUint()。

Append類的函數和Format類的函數工做方式相似,只不過是將轉換後的結果追加到一個slice中。

package main

import (
    "fmt"
    "strconv"
)

func main() {
    // 聲明一個slice
    b10 := []byte("int (base 10):")
    
    // 將轉換爲10進制的string,追加到slice中
    b10 = strconv.AppendInt(b10, -42, 10)
    fmt.Println(string(b10))

    b16 := []byte("int (base 16):")
    b16 = strconv.AppendInt(b16, -42, 16)
    fmt.Println(string(b16))
}

輸出結果:

int (base 10):-42
int (base 16):-2a
相關文章
相關標籤/搜索