Maison >développement back-end >Golang >Comment désorganiser JSON avec des noms de champs inconnus dans Go ?

Comment désorganiser JSON avec des noms de champs inconnus dans Go ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-11 11:28:15405parcourir

How to Unmarshal JSON with Unknown Field Names in Go?

Unmarshal JSON avec des noms de champs inconnus dans une structure

Problème :

Unmarshalling des données JSON avec les noms de champs inconnus peuvent être difficiles lorsque la structure de la réponse JSON est cohérente mais que les noms de champs spécifiques varier.

Solution :

L'utilisation d'une carte comme magasin clé-valeur permet de gérer les instances avec des noms de champs inconnus. La valeur de la carte doit être une structure qui représente la structure commune des données JSON.

Exemple :

Supposons la structure JSON suivante :

{
    "unknown_field": {
        "known_field_1": [[1,2,3,4,5],[10,20,30,40,50],[100,200,300,400,500]],
        "known_field_2": [[11,21,31,41,51]],
        "known_field_3": [[12,22,32,42,52],[14,44,34,44,54]]
    }
}

La structure Go correspondante :

type mData struct {
    KnownField1 [][5]int `json:"known_field_1"`
    KnownField2 [][5]int `json:"known_field_2"`
    KnownField3 [][5]int `json:"known_field_3"`
}

Unmarshaling Code :

var data map[string]mData

if err := json.Unmarshal(body, &data); err != nil {
    panic(err)
}

fmt.Println(data)
for k, v := range data {
    fmt.Println(k, v)
}

Sortie :

map[unknown_field:{[[1 2 3 4 5] [10 20 30 40 50] [100 200 300 400 500]] [[11 21 31 41 51]] [[12 22 32 42 52] [14 44 34 44 54]]}]
unknown_field {[[1 2 3 4 5] [10 20 30 40 50] [100 200 300 400 500]] [[11 21 31 41 51]] [[12 22 32 42 52] [14 44 34 44 54]]}

En exploitant une carte, le code gère efficacement les noms de champs inconnus tout en extrayant avec précision les données dans les champs de structure connus.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn