Conversion des clés Snake Case en JSON en Camel Case dans Go
Question :
Dans Allez, comment pouvons-nous convertir les clés Snake_case dans un JSON en clés CamelCase de manière récursive ? Ceci est particulièrement pertinent pour aligner la réponse API JSON sur les normes internes tout en recevant des données d'un magasin de données comme Elasticsearch, où les formats de clés peuvent varier.
Réponse :
Pour y parvenir conversion, nous pouvons exploiter plusieurs approches. Une méthode efficace utilise la fonctionnalité de Go 1.8 consistant à définir deux structures avec des balises de champ distinctes. En élaborant soigneusement les balises, nous pouvons facilement convertir entre les deux structures, en appliquant efficacement la conversion de clé souhaitée.
Exemple de code utilisant des balises :
<code class="go">package main import ( "encoding/json" "fmt" ) type ESModel struct { AB string `json:"a_b"` } type APIModel struct { AB string `json:"aB"` } func main() { b := []byte(`{ "a_b": "c" }`) var x ESModel json.Unmarshal(b, &x) b, _ = json.MarshalIndent(APIModel(x), "", " ") fmt.Println(string(b)) }</code>
Approche récursive basée sur une carte :
Une autre stratégie globale consiste à tenter de désorganiser le document JSON dans une carte. Si l'opération réussit, nous pouvons corriger méthodiquement les clés et exécuter récursivement la fonction de conversion de clé pour chaque valeur de carte. L'exemple suivant illustre comment convertir toutes les clés en majuscules. La fonction fixKey doit être remplacée par une fonction de conversion Snake_case dans votre implémentation.
<code class="go">package main import ( "bytes" "encoding/json" "fmt" "strings" ) func main() { // Document source as returned by Elasticsearch b := json.RawMessage(`{ "a_b": "c", "d_e": ["d"], "e_f": { "g_h": { "i_j": "k", "l_m": {} } } }`) x := convertKeys(b) buf := &bytes.Buffer{} json.Indent(buf, []byte(x), "", " ") fmt.Println(buf.String()) } func convertKeys(j json.RawMessage) json.RawMessage { m := make(map[string]json.RawMessage) if err := json.Unmarshal([]byte(j), &m); err != nil { // Not a JSON object return j } for k, v := range m { fixed := fixKey(k) delete(m, k) m[fixed] = convertKeys(v) } b, err := json.Marshal(m) if err != nil { return j } return json.RawMessage(b) } func fixKey(key string) string { return strings.ToUpper(key) }</code>
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!