Go で JSON 応答を操作する場合、ネストされた配列内の要素にアクセスすると問題が発生する可能性があります。多くの場合、特定のデータ ポイントを取得しようとすると、「タイプ インターフェイス {} はインデックス付けをサポートしていません」などのエラーが発生します。
これを解決するには、Go の JSON 応答の根本的な性質を理解することが重要です。デフォルトでは、配列は []interface{} スライスとして表され、辞書は map[string]interface{} マップとしてキャストされます。したがって、インターフェイス変数にはインデックス付けのサポートがありません。
ネストされた要素にアクセスするには、型アサーションが必要になります。 1 つのアプローチは、エラー チェックを行わずに次のことを実行することです:
objects := result["objects"].([]interface{})
first := objects[0].(map[string]interface{})
fmt.Println(first["ITEM_ID"])
ただし、型が一致しない場合、このメソッドはパニックを引き起こす可能性があります。より堅牢なアプローチは、2 つの戻り値を使用して潜在的なエラーを処理することです:
objects, ok := result["objects"].([]interface{})
if !ok {
// Handle error
}
JSON が一貫した構造に従っている場合は、カスタム タイプに直接デコードすることを検討してください。
type Result struct {
Query string `json:"query"`
Count int `json:"count"`
Objects []struct {
ItemId string `json:"ITEM_ID"`
ProdClassId string `json:"PROD_CLASS_ID"`
Available int `json:"AVAILABLE"`
} `json:"objects"`
}
デコードされると、result.Objects[0].ItemId.
などのネストされた要素にシームレスにアクセスできます。免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3