Golang String字符串類型轉Json格式
go的string字符串格式轉json格式
確實有點麻煩,如果不知道json里面的類型好像就構建不了結構體了。
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)
}
}
針對包含任意層級的 JOSN 數據,聲明結構體類型比較困難
encode\json 包還提供另外一種方法來解析 JSON 數據。
encoding\json 包使用:
map [string] interface {} 存儲 JOSN 對象
[] interface 存儲 JOSN 數組
json.Unmarshl 將會把任何合法的 JSON 數據存儲到一個 interface {} 類型的值,通過使用空接口類型我們可以存儲任意值,但是使用這種類型作為值時需要先做一次類型斷言。
示例代碼:
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 解析數據流
上面都是使用的 UnMarshall 解析的 JSON 數據,如果 JSON 數據的載體是打開的文件或者 HTTP 請求體這種數據流(他們都是 io.Reader 的實現),我們不必把 JSON 數據讀取出來后再去調用 encode/json 包的 UnMarshall 方法,包提供的 Decode 方法可以完成讀取數據流并解析 JSON 數據最后填充變量的操作。
// 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!
}到此這篇關于Golang String字符串類型轉Json格式的文章就介紹到這了,更多相關Golang String字符串轉Json內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

