Interfaces d'interface d'indexation : Interface d'adressage {} Erreur d'indexation
Lorsque vous travaillez avec des réponses JSON imbriquées, il n'est pas rare de rencontrer l'erreur "invalide opération : le type interface {} ne prend pas en charge l'indexation." Cela se produit lorsque vous tentez d'accéder à des valeurs imbriquées dans une variable typée par l'interface, mais que l'assertion de type correcte n'est pas appliquée.
Considérez l'exemple suivant, en supposant une réponse JSON comme celle fournie :
<code class="go">var d interface{} json.NewDecoder(response.Body).Decode(&d) test := d["data"].(map[string]interface{})["type"]</code>
La ligne tentant d'accéder à la valeur "type" génère une erreur d'indexation car d est de type interface{}, qui ne prend pas en charge l'indexation de type tableau. Pour résoudre ce problème, nous devons taper assert d au type approprié, dans ce cas, une map[string]interface{} :
<code class="go">test := d.(map[string]interface{})["data"].(map[string]interface{})["type"]</code>
Cette assertion de type imbriquée nous permet d'accéder à la valeur "type" avec succès.
Vous pouvez également spécifier le type de d comme map[string]interface{} dès le début :
<code class="go">var d map[string]interface{} json.NewDecoder(response.Body).Decode(&d) test := d["data"].(map[string]interface{})["type"]</code>
En déclarant d comme map[string]interface{} , la première assertion de type est redondante.
De plus, si vous effectuez des opérations similaires à plusieurs reprises, envisagez d'utiliser la bibliothèque github.com/icza/dyno pour faciliter le travail avec des objets dynamiques.
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!