解組非同質性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>
您需要根據「code」欄位將「payload」欄位解組為適當的資料結構。
解決方案
這裡的關鍵是使用 json.RawMessage 類型來延遲「有效負載」欄位的解組,直到您知道其類型為止。例如:
<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中文網其他相關文章!