解组非同质 JSON 数据
此查询以通过利用允许选择性解组特定部分的机制来有效地解组 JSON 数据为中心或片段。目标是处理 JSON 结构,其中第一部分充当“代码”,确定后一部分中包含的数据类型。
想象一个有多个数据结构的场景:
<code class="go">type Range struct { Start int End int } type User struct { ID int Pass int }</code>
您的 JSON 消息有一个“代码”字段,指示“有效负载”字段中的数据:
<code class="json">{ "Code": 4, "Payload": { "Start": 1, "End": 10 } } { "Code": 3, "Payload": { "ID": 1, "Pass": 1234 } }</code>
您需要将“有效负载”字段解组为基于适当数据结构的
解决方案
这里的关键是使用 json.RawMessage 类型来延迟“payload”字段的解组,直到您之后知道它的类型。例如:
<code class="go">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) } }</code>
以上是如何使用'Code”字段解组非同质 JSON 数据?的详细内容。更多信息请关注PHP中文网其他相关文章!