Golang String字符串類型轉(zhuǎn)Json格式
go的string字符串格式轉(zhuǎn)json格式
確實(shí)有點(diǎn)麻煩,如果不知道json里面的類型好像就構(gòu)建不了結(jié)構(gòu)體了。
package main import ( "encoding/json" "fmt" ) type Data struct { Status int `json:"status"` Msg int `json:"msg"` } func main() { msg := "{\"status\":200, \"msg\":18}" var data Data if err := json.Unmarshal([]byte(msg), &data); err == nil { fmt.Println(data.Status) } else { fmt.Println(err) } }
針對(duì)包含任意層級(jí)的 JOSN 數(shù)據(jù),聲明結(jié)構(gòu)體類型比較困難
encode\json 包還提供另外一種方法來(lái)解析 JSON 數(shù)據(jù)。
encoding\json 包使用:
map [string] interface {} 存儲(chǔ) JOSN 對(duì)象 [] interface 存儲(chǔ) JOSN 數(shù)組
json.Unmarshl 將會(huì)把任何合法的 JSON 數(shù)據(jù)存儲(chǔ)到一個(gè) interface {} 類型的值,通過(guò)使用空接口類型我們可以存儲(chǔ)任意值,但是使用這種類型作為值時(shí)需要先做一次類型斷言。
示例代碼:
jsonData := []byte(`{"Name":"Eve","Age":6,"Parents":["Alice","Bob"]}`) var v interface{} json.Unmarshal(jsonData, &v) data := v.(map[string]interface{}) for k, v := range data { switch v := v.(type) { case string: fmt.Println(k, v, "(string)") case float64: fmt.Println(k, v, "(float64)") case []interface{}: fmt.Println(k, "(array):") for i, u := range v { fmt.Println(" ", i, u) } default: fmt.Println(k, v, "(unknown)") } }
用 Decoder 解析數(shù)據(jù)流
上面都是使用的 UnMarshall 解析的 JSON 數(shù)據(jù),如果 JSON 數(shù)據(jù)的載體是打開(kāi)的文件或者 HTTP 請(qǐng)求體這種數(shù)據(jù)流(他們都是 io.Reader 的實(shí)現(xiàn)),我們不必把 JSON 數(shù)據(jù)讀取出來(lái)后再去調(diào)用 encode/json 包的 UnMarshall 方法,包提供的 Decode 方法可以完成讀取數(shù)據(jù)流并解析 JSON 數(shù)據(jù)最后填充變量的操作。
// This example uses a Decoder to decode a stream of distinct JSON values. func ExampleDecoder() { const jsonStream = ` {"Name": "Ed", "Text": "Knock knock."} {"Name": "Sam", "Text": "Who's there?"} {"Name": "Ed", "Text": "Go fmt."} {"Name": "Sam", "Text": "Go fmt who?"} {"Name": "Ed", "Text": "Go fmt yourself!"} ` type Message struct { Name, Text string } dec := json.NewDecoder(strings.NewReader(jsonStream)) for { var m Message if err := dec.Decode(&m); err == io.EOF { break } else if err != nil { log.Fatal(err) } fmt.Printf("%s: %s\n", m.Name, m.Text) } // Output: // Ed: Knock knock. // Sam: Who's there? // Ed: Go fmt. // Sam: Go fmt who? // Ed: Go fmt yourself! }
到此這篇關(guān)于Golang String字符串類型轉(zhuǎn)Json格式的文章就介紹到這了,更多相關(guān)Golang String字符串轉(zhuǎn)Json內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
gin項(xiàng)目部署到服務(wù)器并后臺(tái)啟動(dòng)的步驟
本文主要介紹了gin項(xiàng)目部署到服務(wù)器并后臺(tái)啟動(dòng)的步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02go語(yǔ)言使用Casbin實(shí)現(xiàn)角色的權(quán)限控制
Casbin是用于Golang項(xiàng)目的功能強(qiáng)大且高效的開(kāi)源訪問(wèn)控制庫(kù)。本文主要介紹了go語(yǔ)言使用Casbin實(shí)現(xiàn)角色的權(quán)限控制,感興趣的可以了解下2021-06-06