用陣列和字串解組不一致的JSON 欄位
當資料不一致時,例如當欄位可以字串或字串數組。為了處理這種情況,我們可以採取各種策略。
使用 RawMessage 捕獲不同的資料
對於不同類型的字段,我們可以使用 json.RawMessage 來捕獲未解析的資料資料。這允許我們在解組頂級 JSON 後操作該字段。
使用「-」標記隱藏欄位
隱藏「DisplayName」欄位以防止自動解碼,我們可以在結構體定義中使用「-」標記。這可以防止應用程式在頂級解組期間為該欄位分配值。
確定欄位類型並填入
一旦頂級 JSON 被解碼,我們可以檢查 RawDisplayName 欄位的類型以確定它是字串還是陣列。如果它是字串,我們將其解組為字串切片。如果它是一個數組,我們按照原始問題用“&&”連接值。
自訂解組介面
對於具有不同類型的多個欄位的場景,它將解析邏輯封裝在實作json.Unmarshaler 介面的自訂類型中可能是有益的。這允許對資料轉換過程進行集中控制。
範例實作
以下是處理指定JSON 的範例實作:
package main import ( "encoding/json" "fmt" "strings" ) type multiString string func (ms *multiString) UnmarshalJSON(data []byte) error { *ms = "" if len(data) > 0 { switch data[0] { case '"': var s string if err := json.Unmarshal(data, &s); err != nil { return err } *ms = multiString(s) case '[': var s []string if err := json.Unmarshal(data, &s); err != nil { return err } *ms = multiString(strings.Join(s, "&&")) } } return nil } type MyListItem struct { Date string `json:"date"` DisplayName multiString `json:"display_name"` } type MyListings struct { CLItems []MyListItem `json:"myitems"` } func main() { var listings MyListings err := json.Unmarshal([]byte(`{ "date": "30 Apr", "display_name": "Mr Smith" },{ "date": "30 Apr", "display_name": ["Mr Smith", "Mr Jones"] }`), &listings) if err != nil { fmt.Println(err) return } fmt.Println(listings) }
透過使用這些技術,我們可以有效地對具有不同類型欄位的JSON 進行解組,確保應用程式可以正確處理資料。
以上是如何處理不一致的 JSON 欄位:字串與字串陣列?的詳細內容。更多資訊請關注PHP中文網其他相關文章!