”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何使用“Code”字段解组非同质 JSON 数据?

如何使用“Code”字段解组非同质 JSON 数据?

发布于2024-11-02
浏览:891

How to Unmarshal Non-Homogenous JSON Data with a \

解组非同质 JSON 数据

此查询以通过利用允许选择性解组特定部分的机制来有效地解组 JSON 数据为中心或段。目标是处理 JSON 结构,其中第一部分充当“代码”,确定后一部分中包含的数据类型。

想象一下您有多个数据结构的场景:

type Range struct {
    Start int
    End   int
}

type User struct {
    ID    int
    Pass  int
}

您的 JSON 消息有一个“代码”字段,用于指示“有效负载”字段中的数据:

{
    "Code": 4,
    "Payload": {
        "Start": 1,
        "End": 10
    }
}
{
    "Code": 3,
    "Payload": {
        "ID": 1,
        "Pass": 1234
    }
}

需要根据“code”字段将“payload”字段解组为相应的数据结构。

解决方案

关键这里是使用 json.RawMessage 类型来延迟“payload”字段的解组,直到您知道它的类型。例如:

package main

import (
    "encoding/json"
    "fmt"
)

type Message struct {
    Code    int
    Payload json.RawMessage // Delay parsing until we know the code
}

// Unmarshall into appropriate structures based on Code
func unmarshal(m []byte) error {
    var message Message
    err := json.Unmarshal(m, &message)
    if err != nil {
        return err
    }
    switch message.Code {
    case 3:
        var user User
        if err := json.Unmarshal(message.Payload, &user); err != nil {
            return err
        }
        fmt.Printf("Unmarshalled a User: %#v\n", user)
    case 4:
        var range Range
        if err := json.Unmarshal(message.Payload, &range); err != nil {
            return err
        }
        fmt.Printf("Unmarshalled a Range: %#v\n", range)
    default:
        return fmt.Errorf("unknown code: %d", message.Code)
    }
    return nil
}

func main() {
    json1 := []byte(`{"Code": 3, "Payload": {"ID": 1, "Pass": 1234}}`)
    if err := unmarshal(json1); err != nil {
        fmt.Printf("error: %v\n", err)
    }

    json2 := []byte(`{"Code": 4, "Payload": {"Start": 1, "End": 10}}`)
    if err := unmarshal(json2); err != nil {
        fmt.Printf("error: %v\n", err)
    }
}
最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3