donglian1982 2018-02-10 00:52
浏览 99
已采纳

golang json解码并带有字段名

For following JSON

{
    "Jon": {
       "Age": 15
    },
    "Mary": {
       "Age": 17
    } 
}

how can i map it into golang struct, normally, the structure will be

type Person struct {
    Name string `json:??,string`
    Age int `json:Age, int`
}

as the json field name is the attribute of struct, thank you in advance.

  • 写回答

1条回答 默认 最新

  • dongluojiao6322 2018-02-10 01:47
    关注

    You have to use custom JSON marshalling

    package main
    
        import (
            "encoding/json"
            "log"
            "fmt"
        )
    
        type Person struct {
            Name string `json:??,string`
            Age  int    `json:Age, int`
        }
    
        type People map[string]*Person
    
        func (p *People) UnmarshalJSON(data []byte) error {
            var transient = make(map[string]*Person)
            err := json.Unmarshal(data, &transient)
            if err != nil {
                return err
            }
            for k, v := range transient {
                v.Name = k
                (*p)[k] = v
            }
            return nil
        }
    
        func main() {
    
            jsonInput := `
            {
                "Jon": {
            "Age": 15
            },
                "Mary": {
            "Age": 17
            }
            }
        `
    
            var people People = make(map[string]*Person)
    
            err := people.UnmarshalJSON([]byte(jsonInput))
            if err != nil {
                log.Fatal(err)
            }
    
            for _, person := range people {
                fmt.Printf("%v -> %v
    ", person.Name, person.Age)
            }
        }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据