您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“如何使用Go語言JSON 標(biāo)準(zhǔn)庫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“如何使用Go語言JSON 標(biāo)準(zhǔn)庫”吧!
序列化使用 json 庫中的Marshal
函數(shù):
func Marshal(v interface{}) ([]byte, error)
比如使用以下的結(jié)構(gòu)體表示一部電影:
type Movie struct { Title string Year int `json:"released"` Color bool `json:"color,omitempty"` Actors []string }
定義里類型后面跟的字符串 json:"released"
和json:"color,omitempty
,稱為 field tags,它告訴 json 庫在執(zhí)行序列化時(shí)的一些規(guī)則:
json:"released"
使得在序列化后對(duì)應(yīng)的名字為"released",而不是"Year"。
json:"color,omitempty"
使得如果 Color 成員的值為false
,那么就忽略它,不對(duì)它進(jìn)行序列化。
沒有 field tags 時(shí)進(jìn)行序列化的一些規(guī)則:
如果結(jié)構(gòu)體成員的名字不是以大寫字母開頭,則不對(duì)它進(jìn)行序列化。
如果結(jié)構(gòu)體成員的名字是以大寫字母開頭,則序列化后的名字就是成員名。
進(jìn)行序列化的代碼如下:
movie := Movie{ Title: "Casablanca", Year: 1942, Color: false, Actors: []string{"Humphrey Bogart", "Ingrid Bergman"}, } data, err := json.Marshal(movie) if err != nil { log.Fatalf("JSON marshaling failed: %s", err) } fmt.Printf("%s\n", data)
輸出:
{"Title":"Casablanca","released":1942,"Actors":["Humphrey Bogart","Ingrid Bergman"]}
一個(gè)字典要想序列化成- JSON 格式,它的 key 必須是字符串。
以下是一個(gè)例子:
info := map[string]int{ "width": 1280, "height": 720, } data, err := json.MarshalIndent(info, "", " ") if err != nil { log.Fatalf("JSON marshaling failed: %s", err) } fmt.Printf("%s\n", data)
輸出:
{
"height": 720,
"width": 1280
}
這里我們使用MarshalIndent
函數(shù),使得輸出后的 JSON 格式更易閱讀。序列化后的名字就是字典中 key 的名稱。
直接看一個(gè)例子:
type Movie struct { Title string Year int `json:"released"` Color bool `json:"color,omitempty"` Actors []string } var movies = []Movie{ { Title: "Casablanca", Year: 1942, Color: false, Actors: []string{"Humphrey Bogart", "Ingrid Bergman"}, }, { Title: "Cool Hand Luke", Year: 1967, Color: true, Actors: []string{"Paul Newman"}, }, { Title: "Bullitt", Year: 1968, Color: true, Actors: []string{"Steve McQueen", "Jacqueline Bisset"}, }, } data, err := json.MarshalIndent(movies, "", " ") if err != nil { log.Fatalf("JSON marshaling failed: %s", err) } fmt.Printf("%s\n", data)
輸出:
[
{
"Title": "Casablanca",
"released": 1942,
"Actors": [
"Humphrey Bogart",
"Ingrid Bergman"
]
},
{
"Title": "Cool Hand Luke",
"released": 1967,
"color": true,
"Actors": [
"Paul Newman"
]
},
{
"Title": "Bullitt",
"released": 1968,
"color": true,
"Actors": [
"Steve McQueen",
"Jacqueline Bisset"
]
}
]
反序列化使用Unmarshal
函數(shù):
func Unmarshal(data []byte, v interface{}) error
我們要先將 JSON 格式表示為一個(gè)確定的類型。
1.如下的 JSON 格式:
{ "name": "Awesome 4K", "resolutions": [ { "width": 1280, "height": 720 }, { "width": 1920, "height": 1080 }, { "width": 3840, "height": 2160 } ] }
我們可以用如下結(jié)構(gòu)體來表示它:
struct { Name string Resolutions []struct { Width int Height int } }
2.如下的 JSON 格式:
{ "height": 720, "width": 1280 }
也可以使用map[string]int
,也就是字典來表示。
3.如下的 JSON 格式:
[ { "width": 1280, "height": 720 }, { "width": 1920, "height": 1080 }, { "width": 3840, "height": 2160 } ]
使用切片[]map[string]int
來表示。
不管怎樣,一個(gè)確定的JSON格式總是可以使用切片、結(jié)構(gòu)體或字典來表示。
之后就可以執(zhí)行反序列化了:
var jsonBlob = []byte(` [ { "width": 1280, "height": 720 }, { "width": 1920, "height": 1080, }, { "width": 3840, "height": 2160 } ] `) di := []map[string]int{} err = json.Unmarshal(jsonBlob, &di) if err != nil { fmt.Println("error:", err) } fmt.Printf("%+v\n", di)
輸出
[map[height:720 width:1280] map[height:1080 width:1920] map[height:2160 width:3840]]
無法確定的格式可以直接使用interface{}
類型來表示。這個(gè)時(shí)候,如果是JSON對(duì)象,則反序列化時(shí) json 庫會(huì)使用map[string]interface{}
類型來表示它。如果是JSON數(shù)組,則會(huì)使用[]interface{}
類型來表示它。具體interface{}
對(duì)應(yīng)的具體類型,就需要使用類型斷言了。
具體看一個(gè)示例:
package main import ( "encoding/json" "fmt" ) func main() { var jsonBlob = []byte(` { "name": "Awesome 4K", "price": 1999.9, "resolutions": [ { "width": 1280, "height": 720 }, { "width": 1920, "height": 1080 }, { "width": 3840, "height": 2160 } ] } `) var d interface{} err := json.Unmarshal(jsonBlob, &d) if err != nil { fmt.Println("error:", err) } fmt.Println(d) m := d.(map[string]interface{}) for k, v := range m { switch vv := v.(type) { case string: fmt.Println(k, "is string", vv) case float64: fmt.Println(k, "is float64", vv) case []interface{}: fmt.Println(k, "is an array:") for i, u := range vv { fmt.Println(i, u) } default: fmt.Println(k, "is of a type I don't know how to handle") } } }
輸出:
map[name:Awesome 4K price:1999.9 resolutions:[map[height:720 width:1280] map[height:1080 width:1920] map[height:2160 width:3840]]]
resolutions is an array:
0 map[height:720 width:1280]
1 map[height:1080 width:1920]
2 map[height:2160 width:3840]
name is string Awesome 4K
price is float64 1999.9
到此,相信大家對(duì)“如何使用Go語言JSON 標(biāo)準(zhǔn)庫”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。