Go標(biāo)準(zhǔn)庫strconv實現(xiàn)string類型與其他基本數(shù)據(jù)類型之間轉(zhuǎn)換
前言
上篇文章介紹了 strings
標(biāo)準(zhǔn)庫里的一些常用的函數(shù)和方法,本文也是以 string
類型為中心,通過 strconv
標(biāo)準(zhǔn)庫,介紹其與其他基本數(shù)據(jù)類型相互轉(zhuǎn)換的函數(shù)。
strconv
strconv
包提供了 string
類型與其他基本數(shù)據(jù)類型之間轉(zhuǎn)換的函數(shù),本文不會介紹其所有函數(shù),如果想了解更多的小伙伴可以到 Go 包文檔 查看。
string 與 int 之間的轉(zhuǎn)換
Itoa:int 類型轉(zhuǎn) string 類型
Itoa(i int) string
- 參數(shù)
i
為待轉(zhuǎn)換的數(shù)字。
返回值為轉(zhuǎn)換之后的字符串。
import ( "fmt" "strconv" ) func main() { num := 16 str := strconv.Itoa(num) fmt.Printf("類型:%T,值:%s", str, str) // 類型:string,值:16 }
Atoi:string 類型轉(zhuǎn) int 類型
Atoi(s string) (int, error)
- 函數(shù)的參數(shù)為待轉(zhuǎn)換的字符串
返回值有兩個,第一個是轉(zhuǎn)換之后的整形數(shù)字,第二個是錯誤描述。
import ( "fmt" "strconv" ) func main() { str := "666" num, err := strconv.Atoi(str) if err != nil { fmt.Println("err: ", err.Error()) return } fmt.Printf("類型:%T,值:%d", num, num) // 類型:int,值:666 }
此函數(shù)與 Itoa
函數(shù)相比,多了一個 error
返回值,是因為如果是傳入的字符串無法轉(zhuǎn)成數(shù)字,例如 1a1
,此函數(shù)就會返回 NumError
錯誤,而 Itoa
函數(shù),無論傳入的是什么樣的數(shù)字,都可以轉(zhuǎn)為 string
,因此在轉(zhuǎn)換的過程中沒有 error
的說法。
FormatInt:將數(shù)字轉(zhuǎn)成指定進(jìn)制數(shù)并以 string 類型返回
FormatInt(i int64, base int) string
- 第一個參數(shù)為指定數(shù)字,類型為
int64
- 第二個參數(shù)為指定進(jìn)制
第三個參數(shù)為數(shù)字轉(zhuǎn)成指定進(jìn)制數(shù)后的字符串
import ( "strconv" ) func main() { var num int64 = 2 str := strconv.FormatInt(num, 2) var num2 int64 = 17 str2 := strconv.FormatInt(num2, 16) println(str) // 10 println(str2) // 11 }
上述代碼實現(xiàn)了將數(shù)字 2
轉(zhuǎn)成二進(jìn)制的形式 10
,將數(shù)字 17
轉(zhuǎn)成十六進(jìn)制的形式 11
,并以 string 類型返回。上述數(shù)字皆代表著有符號為的 int64
類型,與之對應(yīng)的還有無符號位的 uint64
類型的轉(zhuǎn)換函數(shù) FormatUint
。
ParseInt:給定基數(shù)(進(jìn)制數(shù))和位數(shù),返回對應(yīng)十進(jìn)制的值
ParseInt(s string, base int, bitSize int) (i int64, err error)
- 第一個參數(shù)
s
為待解析的字符串 - 第二個參數(shù)
base
為基數(shù),也就是進(jìn)制數(shù),從0
、2
到36
進(jìn)制。 - 第三個參數(shù)
bitSize
為位數(shù),0
、8
、16
、32
、64
位分別對應(yīng)int
、int8
、int16
、int32
、int64
。如果bitSize
小于0
或大于64
,則返回錯誤。 - 第一個返回值
i
為轉(zhuǎn)換之后的數(shù)字
第二個返回值 err
為轉(zhuǎn)換時產(chǎn)生的錯誤信息,除了 bitSize
小于 0
或大于 64
,會發(fā)生錯誤以外,如果所傳的字符串 s
與 base
參數(shù)或 bitSize
參數(shù)不匹配,也會發(fā)生錯誤。
import ( "fmt" "strconv" ) func main() { parseInt, err := strconv.ParseInt("100", 2, 64) if err != nil { fmt.Println(err.Error()) return } println(parseInt) // 4 parseInt2, err := strconv.ParseInt("666", 2, 64) if err != nil { fmt.Println(err.Error()) // strconv.ParseInt: parsing "666": invalid syntax return } println(parseInt2) }
首先將二進(jìn)制的 100
轉(zhuǎn)成十進(jìn)制,為 4
,然后將二進(jìn)制的 666
轉(zhuǎn)成十進(jìn)制,但是二進(jìn)制所對應(yīng)的數(shù)字沒有 666,因此轉(zhuǎn)換錯誤,返回 strconv.ParseInt: parsing "666": invalid syntax
錯誤信息。與之對應(yīng)的還有返回?zé)o符號位的 uint64
類型的轉(zhuǎn)換函數(shù) ParseUint
。
string 與 float 之間的轉(zhuǎn)換
ParseFloat:字符串類型轉(zhuǎn)浮點型類型
ParseFloat(s string, bitSize int) (float64, error)
- 第一個參數(shù)
s
為帶轉(zhuǎn)換的字符串。 - 第二個參數(shù)為
bitSize
為轉(zhuǎn)換后的位數(shù),32
代表float32
,64
代表float64
。 - 第一個返回值為轉(zhuǎn)換后的浮點型數(shù)字。
第二個返回值為轉(zhuǎn)換過程中所產(chǎn)生的錯誤
import ( "fmt" "strconv" ) func main() { num, err := strconv.ParseFloat("11.05", 64) if err != nil { return } fmt.Println(num) }
如果傳入的 s
的語法錯誤如 1s1
,則轉(zhuǎn)換失敗,返回 error
。
FormatFloat:根據(jù)格式 fmt 和精度 prec 將浮點數(shù) f 轉(zhuǎn)換為字符串
FormatFloat(f float64, fmt byte, prec, bitSize int) string
- 第一個參數(shù)
f
為待轉(zhuǎn)換的浮點數(shù)。 - 第二個參數(shù)為格式,可選值有
b e E f g G x X
。 - 第三個參數(shù)
prec
為精度,精確到幾位小數(shù)。 - 返回值為轉(zhuǎn)換后的字符串。
import ( "fmt" "strconv" ) func main() { str := strconv.FormatFloat(5.26, 'f', 1, 64) fmt.Println(str) // 5.3 }
FormatFloat
函數(shù)會對結(jié)果值進(jìn)行四舍五入計算。
string 與 bool 之間的轉(zhuǎn)換
ParseBool:字符串轉(zhuǎn)布爾值
ParseBool(str string) (bool, error)
- 第一個參數(shù)
str
為待轉(zhuǎn)換的字符串 - 第一個返回值為轉(zhuǎn)換之后的
bool
值
第二個返回值為轉(zhuǎn)換時所產(chǎn)生的錯誤。
import ( "fmt" "strconv" ) func main() { bool1, err := strconv.ParseBool("true") if err != nil { fmt.Println(err.Error()) return } fmt.Println(bool1) // true bool2, err := strconv.ParseBool("golang") if err != nil { fmt.Println(err.Error()) // strconv.ParseBool: parsing "golang": invalid syntax return } fmt.Println(bool2) }
第一個字符串 true
轉(zhuǎn)布爾值成功了,但是第二個字符串 golang
轉(zhuǎn)布爾值失敗了,因為 bool
類型的可選值只有 true
和 false
,其他值無法轉(zhuǎn)成布爾值。
FormatBool:布爾值轉(zhuǎn)字符串
FormatBool(b bool) string
- 參數(shù)
b
為帶轉(zhuǎn)換的布爾值。
返回值為轉(zhuǎn)換之后的字符串。
import ( "fmt" "strconv" ) func main() { boolStr := strconv.FormatBool(true) fmt.Println(boolStr) // "true" }
小結(jié)
本文對 string
與 int
類型、float
類型和 bool
類型相互之間轉(zhuǎn)換的函數(shù)進(jìn)行介紹,掌握這些函數(shù)的用法,應(yīng)對開發(fā)中 string
類型與其他基本數(shù)據(jù)類型轉(zhuǎn)換的場景不成問題,更多關(guān)于Go strconv類型轉(zhuǎn)換的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Go中字符串處理?fmt.Sprintf與string.Builder的區(qū)別對比分析
在Go語言中,我們通常會遇到兩種主要的方式來處理和操作字符串:使用fmt.Sprintf函數(shù)和string.Builder類型,本文給大家介紹它們在性能和用法上有一些關(guān)鍵區(qū)別,感興趣的朋友跟隨小編一起看看吧2023-11-11GO項目實戰(zhàn)之Gorm格式化時間字段實現(xiàn)
GORM自帶的time.Time類型JSON默認(rèn)輸出RFC3339Nano格式的,下面這篇文章主要給大家介紹了關(guān)于GO項目實戰(zhàn)之Gorm格式化時間字段實現(xiàn)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01在go文件服務(wù)器加入http.StripPrefix的用途介紹
這篇文章主要介紹了在go文件服務(wù)器加入http.StripPrefix的用途介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12獲取Golang環(huán)境變量的三種方式小結(jié)
本文介紹了Golang中獲取環(huán)境變量的三種方式,包含使用Viper包、GoDotEnv包和os包,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-11-11golang如何實現(xiàn)mapreduce單進(jìn)程版本詳解
這篇文章主要給大家介紹了關(guān)于golang如何實現(xiàn)mapreduce單進(jìn)程版本的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01