Heim  >  Artikel  >  Backend-Entwicklung  >  Wie kann ich JSON-Daten entmarshalieren und in einer Struktur in Go speichern?

Wie kann ich JSON-Daten entmarshalieren und in einer Struktur in Go speichern?

PHPz
PHPznach vorne
2024-02-11 19:48:08772Durchsuche

我如何解组 JSON 数据并将其存储在 Go 中的结构中

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.

Frageninhalt

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

Workaround

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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:stackoverflow.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen