Heim >Backend-Entwicklung >Golang >Wie kann ich JSON-Daten entmarshalieren und in einer Struktur in Go speichern?
php-Editor Strawberry teilt eine Methode zum Entpacken von JSON-Daten und zum Speichern dieser in einer Go-Sprachstruktur. JSON ist ein häufig verwendetes Datenaustauschformat und die Go-Sprache bietet ein praktisches Toolkit zum Parsen und Verarbeiten von JSON-Daten. Durch die Verwendung des in die Go-Sprache integrierten „json“-Pakets können wir JSON-Daten einfach in entsprechende Strukturen zerlegen, speichern und verarbeiten. Diese Methode ist einfach und leicht zu verstehen und kann Entwicklern dabei helfen, JSON-Daten effizient zu verarbeiten und die Entwicklungseffizienz zu verbessern. Im Folgenden stellen wir detailliert vor, wie Sie die Go-Sprache verwenden, um JSON-Daten zu entpacken und in einer Struktur zu speichern.
Dies sind die JSON-Testdaten, die ich mit go struct in meinem Programm gespeichert habe
[ { "id": 393, "question": "the \"father\" of mysql is ______.", "description": null, "answers": { "answer_a": "bill joy", "answer_b": "stephanie wall", "answer_c": "bill gates", "answer_d": "michael widenius", "answer_e": null, "answer_f": null }, "multiple_correct_answers": "false", "correct_answers": { "answer_a_correct": "false", "answer_b_correct": "false", "answer_c_correct": "false", "answer_d_correct": "true", "answer_e_correct": "false", "answer_f_correct": "false" }, "correct_answer": "answer_a", "explanation": null, "tip": null, "tags": [ { "name": "mysql" } ], "category": "sql", "difficulty": "medium" } ]
Dies ist die Funktion, die ich geschrieben habe, um die Daten zu speichern, aber ich kann nicht die richtige Antwort erhalten, anstatt beim Drucken eine leere Struktur zu erhalten
func FetchQuiz(num int, category string) { // write code to read json file jsonFile, err := os.Open("test.json") if err != nil { fmt.Println(err) } defer jsonFile.Close() byteValue, _ := ioutil.ReadAll(jsonFile) fmt.Println(string(byteValue)) type Data struct { ID int Question string Description string Answers struct { A string B string C string D string E string F string } MultipleCorrectAnswers string CorrectAnswers struct { A string B string C string D string E string F string } CorrectAnswer string Explanation string Tip string Tags []struct { Name string } Category string Difficulty string } var QuizList2 []Data if err := json.Unmarshal(byteValue, &QuizList2); err != nil { fmt.Println(err.Error()) } fmt.Println(QuizList2)
Aber die Antwort, die ich bekam, war [{393 Der „Vater“ von MySQL ist ______. { } { } [{mysql}] sql medium}] Ich habe alles versucht, um das Problem zu lösen, bekomme aber keine Antwort
json-Feld answer_a
不会单独映射到 go 字段 a
.
Ändern Sie den Namen des Go-Felds so, dass er mit dem Namen des JSON-Felds übereinstimmt (Groß- und Kleinschreibung ignorieren):
answer_a string
Oder verwenden Sie das struct-Tag in Ihrem Bereich:
A string `json:"answer_a"`
Machen Sie dasselbe für die verbleibenden Go-Felder, die nicht mit dem entsprechenden JSON-Feld übereinstimmen.
Das obige ist der detaillierte Inhalt vonWie kann ich JSON-Daten entmarshalieren und in einer Struktur in Go speichern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!