JSON(Javascript Object Notation)是一種輕量級(jí)的數(shù)據(jù)交換語言,以文字為基礎(chǔ),具有自我描述性且易于讓人閱讀。盡管JSON是JavaScript的一個(gè)子集,但JSON是獨(dú)立于語言的文本格式,并且采用了類似于C語言家族的一些習(xí)慣。JSON與XML最大的不同在于XML是一個(gè)完整的標(biāo)記語言,而JSON不是。JSON由于比XML更小、更快,更易解析,以及瀏覽器的內(nèi)建快速解析支持,使得其更適用于網(wǎng)絡(luò)數(shù)據(jù)傳輸領(lǐng)域。
Golang自帶的JSON解析庫encoding/json,可以用起將結(jié)構(gòu)化數(shù)據(jù)序列化成json字符串或從json字符串中解析出我們想要的數(shù)據(jù)。
1.解析json
給一個(gè)較為復(fù)雜的json字符串,包含數(shù)組,數(shù)組的元素是json對(duì)象。我們需要取出數(shù)組第一個(gè)元素中的某一個(gè)字段值。其它的解析均可參考下面的代碼。
package main
import (
"encoding/json"
"fmt"
)
func main() {
jsonStr := []byte(`{"uin":1589276509,"feedID":10000,"videos":[{"picture":"http://qqpublic.qpic.cn/avatar.jpg","duration":"839"}]}`)
var jsonMap map[string]interface{}
if err := json.Unmarshal(jsonStr, jsonMap); err!=nil {
fmt.Printf("json decode failed, err=%v", err)
return
}
value, ok:=jsonMap["videos"]
fmt.Printf("value=%#v\n", value)
if ok {
sliceValue, ok := value.([]interface{})
if ok {
mapValue, ok := sliceValue[0].(map[string]interface{})
if ok {
duration, ok := mapValue["duration"]
if ok {
fmt.Printf("d=%v,type=%T\n",duration,duration)
}
}
}
}
}
程序輸出:
value=[]interface {}{map[string]interface {}{"picture":"http://qqpublic.qpic.cn/avatar.jpg", "duration":"839"}}
d=839,type=string
解析json字符串時(shí),需要注意如下幾點(diǎn):
(1)Go類型和JSON類型的對(duì)應(yīng)關(guān)系如下:
map[string]interface{}代表JSON對(duì)象
[]interface{}代表JSON數(shù)組
bool代表JSON booleans
float64代表JSON numbers
string代表JSON strings
nil 代表JSON null
2.生成json
假設(shè)我們有如下一個(gè)類(結(jié)構(gòu)體)student 及其一個(gè)實(shí)例對(duì)象st,將其序列化為json,具體實(shí)現(xiàn)如下:
package main
import (
"encoding/json"
"fmt"
)
type Stu struct {
Name string `json:"name"`
Age int
sex string
Class *Class `json:"class"`
}
type Class struct {
Name string
Grade int
}
func main() {
//實(shí)例化一個(gè)數(shù)據(jù)結(jié)構(gòu),用于生成json字符串
stu := Stu{
Name: "張三",
Age: 18,
sex: "男",
}
//指針變量
cla := new(Class)
cla.Name = "1班"
cla.Grade = 3
stu.Class=cla
//Marshal失敗時(shí)err!=nil
jsonStu, err := json.Marshal(stu)
if err != nil {
fmt.Println("生成json字符串錯(cuò)誤")
}
//jsonStu是[]byte類型,轉(zhuǎn)化成string類型便于查看
fmt.Println(string(jsonStu))
}
程序輸出結(jié)果:
{"name":"張三","Age":18,"class":{"Name":"1班","Grade":3}}
閱讀以上代碼可以看出:
(1)只要是可導(dǎo)出成員(變量首字母大寫),都可以轉(zhuǎn)成json。因成員變量sex是不可導(dǎo)出的,故無法轉(zhuǎn)成json;
(2)如果變量打上了json標(biāo)簽,如Name旁邊的 json:"name"
,那么轉(zhuǎn)化成的json key就用該標(biāo)簽“name”,否則取字段名作為key,如"Age";
(3)指針變量,編碼時(shí)自動(dòng)轉(zhuǎn)換為它所指向的值,如Class變量;
(4)強(qiáng)調(diào)一句,序列化成功后的json字符串是純粹的字符串。
以上就是Golang 如何解析和生成json的詳細(xì)內(nèi)容,更多關(guān)于golang 解析、生成json的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- golang 實(shí)現(xiàn)json類型不確定時(shí)的轉(zhuǎn)換
- golang中json的omitempty使用操作
- golang:json 反序列化的[]和nil操作
- 解決Golang json序列化字符串時(shí)多了\的情況
- 解決golang json解析出現(xiàn)值為空的問題
- golang xorm及time.Time自定義解決json日期格式的問題
- golang 實(shí)現(xiàn)struct、json、map互相轉(zhuǎn)化
- golang中json小談之字符串轉(zhuǎn)浮點(diǎn)數(shù)的操作