So analysieren Sie ein komplexes JSON mit Go Unmarshal: Enthüllen des Innenlebens
Das Paket „encoding/json“ in Go bietet json.Unmarshal Funktion zur Vereinfachung von JSON-Parsing-Aufgaben. Der Umgang mit komplexen JSON-Strukturen kann sich jedoch als Herausforderung erweisen.
Dekodierung in eine Schnittstelle{}
Für unbekannte JSON-Daten kann man sie mit Unmarshal in eine Schnittstelle dekodieren{} . Dieser Ansatz führt zu einem Map[string]interface{}-Wert, bei dem Schlüssel Zeichenfolgen und Werte interface{}-Typen sind.
Betrachten Sie beispielsweise den folgenden JSON:
{ "k1" : "v1", "k2" : "v2", "k3" : 10, "result" : [ [ ["v4", v5, {"k11" : "v11", "k22" : "v22"}] , ... , ["v4", v5, {"k33" : "v33", "k44" : "v44"} ] ], "v3" ] }
The Go Code zum Dekodieren und Zugreifen auf diese Daten:
package main import ( "encoding/json" "fmt" ) func main() { b := []byte(`{ "k1" : "v1", "k3" : 10, result:["v4",12.3,{"k11" : "v11", "k22" : "v22"}] }`) var f interface{} err := json.Unmarshal(b, &f) if err != nil { fmt.Println(err) return } m := f.(map[string]interface{}) for k, v := range m { switch vv := v.(type) { case string: fmt.Println(k, "is string", vv) case int: fmt.Println(k, "is int", 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") } } }
Durch die Bestätigung des Schnittstellentyps und die Verwendung eines Typschalters ist eine Navigation möglich
Das obige ist der detaillierte Inhalt vonWie kann man komplexe JSON-Strukturen in Go mit „json.Unmarshal' effektiv analysieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!