Spécification des valeurs par défaut dans l'analyse JSON avec Go
Lors de l'analyse des objets JSON dans Go, il peut être nécessaire de spécifier des valeurs par défaut pour les champs qui ne sont pas fournis dans le JSON d’entrée. Considérons un type de structure avec les champs suivants :
type Test struct { A string B string C string }
Supposons que les valeurs par défaut souhaitées pour A, B et C soient respectivement "a", "b" et "c". Lors de l'analyse du JSON suivant :
{"A": "1", "C": 3}
la structure attendue serait :
Test{A: "1", B: "b", C: "3"}
Utilisation du package encoding/json
Le construit -in encoding/json package dans Go permet de spécifier des valeurs par défaut lors de l'analyse JSON. Au lieu d'utiliser une structure vide, fournissez une structure avec les valeurs par défaut souhaitées comme suit :
var example []byte = []byte(`{"A": "1", "C": "3"}`) out := Test{ A: "default a", B: "default b", // default for C will be "", the empty value for a string } err := json.Unmarshal(example, &out) // <- if err != nil { panic(err) } fmt.Printf("%+v", out)
En appelant json.Unmarshal(example, &out), le JSON n'est pas marshalé dans la structure out, écrasant les valeurs. spécifié dans le JSON. Cependant, les valeurs par défaut des champs non présents dans le JSON restent inchangées. L'exécution de l'exemple renvoie :
{A:1 B:default b C:3}
Autres bibliothèques Go
Si le package encoding/json ne répond pas à des exigences spécifiques, il existe d'autres bibliothèques Go qui offrent des fonctionnalités similaires. . Considérez ce qui suit :
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!