首页 > 后端开发 > Golang > 如何将具有意外字段名称的 JSON 解组到 Go 结构中?

如何将具有意外字段名称的 JSON 解组到 Go 结构中?

Mary-Kate Olsen
发布: 2024-12-24 12:29:18
原创
784 人浏览过

How to Unmarshal JSON with Unexpected Field Names into a Go Struct?

使用未知字段名解组 JSON 到结构

问题:

是否可以使用未知字段名解组 JSON提前,同时保持给定的结构?

问题:

考虑一个 JSON 响应,其中未知的字段名称包装一个公共结构。此结构必须映射到结构,但字段名称会有所不同。

{
    "unknown_field": {
            "known_field_1": [[1,2,3,4,5],[10,20,30,40,50],[100,200,300,400,500]],
            "known_field_2": [[11,21,31,41,51]],
            "known_field_3": [[12,22,32,42,52],[14,44,34,44,54]]
        }
}
登录后复制

答案:

是的,可以使用映射来解组此类 JSON,如下所示根结构元素,其中键是未知字段名,值是已知字段名的实例结构体。

type mData struct {
    KnownField1 [][5]int `json:"known_field_1"`
    KnownField2 [][5]int `json:"known_field_2"`
    KnownField3 [][5]int `json:"known_field_3"`
}
登录后复制
var data map[string]mData
if err := json.Unmarshal(body, &data); err != nil {
    panic(err)
}
登录后复制

输出:

map[unknown_field:{[[1 2 3 4 5] [10 20 30 40 50] [100 200 300 400 500]] [[11 21 31 41 51]] [[12 22 32 42 52] [14 44 34 44 54]]}]
unknown_field {[[1 2 3 4 5] [10 20 30 40 50] [100 200 300 400 500]] [[11 21 31 41 51]] [[12 22 32 42 52] [14 44 34 44 54]]}
登录后复制

以上是如何将具有意外字段名称的 JSON 解组到 Go 结构中?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板