Maison > Article > développement back-end > Comment éviter les erreurs « opération invalide : l'interface de type {} ne prend pas en charge l'indexation » lors du décodage du JSON imbriqué ?
Décodage du JSON imbriqué et gestion des problèmes d'assertion de type
Lors de la récupération de données JSON imbriquées, il est essentiel de gérer les assertions de type de manière appropriée pour éviter les erreurs d'exécution. L'une de ces erreurs est "Opération invalide : type interface {} ne prend pas en charge l'indexation".
Cette erreur se produit généralement lorsque vous tentez d'indexer une valeur d'interface{} comme s'il s'agissait d'une carte ou d'une tranche, comme dans le exemple suivant :
<code class="go">var d interface{} json.NewDecoder(response.Body).Decode(&d) test := d["data"].(map[string]interface{})["type"]</code>
Pour résoudre ce problème, vous devez effectuer des assertions de type supplémentaires pour convertir la valeur interface{} dans le type attendu. Dans ce cas, vous devez d'abord convertir l'interface{} en map[string]interface{}, puis accéder au champ "data" et le convertir en une autre map[string]interface{} avant d'accéder enfin au champ "type".
<code class="go">test := d.(map[string]interface{})["data"].(map[string]interface{})["type"]</code>
Vous pouvez également déclarer d comme étant de type map[string]interface{} directement, éliminant ainsi le besoin de l'assertion de type initiale :
<code class="go">var d map[string]interface{} json.NewDecoder(response.Body).Decode(&d) test := d["data"].(map[string]interface{})["type"]</code>
Si vous effectuez fréquemment Pour des assertions de type similaire, envisagez d'utiliser une bibliothèque comme github.com/icza/dyno pour simplifier le processus.
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!