在Go中,可以使用以下幾種方式來解析JSON數(shù)據(jù):
encoding/json
包:encoding/json
包提供了Unmarshal()
函數(shù),可以將JSON數(shù)據(jù)解析為Go結(jié)構(gòu)體對(duì)象。使用該函數(shù)時(shí),首先需要定義一個(gè)結(jié)構(gòu)體類型,該結(jié)構(gòu)體的字段名和類型需要與JSON數(shù)據(jù)中的字段名和類型保持一致。然后,使用Unmarshal()
函數(shù)將JSON數(shù)據(jù)解析為該結(jié)構(gòu)體對(duì)象。type Person struct {
Name string `json:"name"`
Age int `json:"age"`
}
jsonStr := `{"name":"Alice","age":25}`
var person Person
err := json.Unmarshal([]byte(jsonStr), &person)
if err != nil {
panic(err)
}
fmt.Printf("Name: %s, Age: %d\n", person.Name, person.Age)
json.Unmarshal()
函數(shù):json.Unmarshal()
函數(shù)可以將JSON數(shù)據(jù)解析為一個(gè)map[string]interface{}
類型的對(duì)象,其中map
的鍵是字段名,interface{}
表示任意類型的值。使用該函數(shù)需要先將JSON數(shù)據(jù)轉(zhuǎn)換為[]byte
類型,然后調(diào)用json.Unmarshal()
函數(shù)進(jìn)行解析。jsonStr := `{"name":"Alice","age":25}`
var data map[string]interface{}
err := json.Unmarshal([]byte(jsonStr), &data)
if err != nil {
panic(err)
}
fmt.Printf("Name: %s, Age: %f\n", data["name"].(string), data["age"].(float64))
json.Decoder
:json.Decoder
提供了Decode()
方法,可以逐個(gè)解析JSON數(shù)據(jù)中的值,并將其存儲(chǔ)到相應(yīng)的變量中。使用json.Decoder
可以逐步處理JSON數(shù)據(jù),適用于大型JSON數(shù)據(jù)或流式數(shù)據(jù)的解析。type Person struct {
Name string `json:"name"`
Age int `json:"age"`
}
jsonStr := `{"name":"Alice","age":25}`
var person Person
dec := json.NewDecoder(strings.NewReader(jsonStr))
for {
if err := dec.Decode(&person); err == io.EOF {
break
} else if err != nil {
panic(err)
}
fmt.Printf("Name: %s, Age: %d\n", person.Name, person.Age)
}
無論使用哪種方式,都需要在解析JSON數(shù)據(jù)時(shí)處理錯(cuò)誤,以確保解析過程正確無誤。