Benutzerdefiniertes Unmarshaling mit String-Split in Go
Beim Umgang mit JSON-Daten besteht häufig die Notwendigkeit, den Unmarshaling-Prozess für bestimmte Zwecke zu transformieren oder anzupassen Datentypen. In diesem Fall möchten wir einen JSON-String, der durch Kommas getrennte Werte enthält, beim Unmarshalling in ein []String-Slice aufteilen.
Um dies zu erreichen, implementieren wir einen benutzerdefinierten Unmarshaler für den []String-Typ:
type strslice []string
func (ss *strslice) UnmarshalJSON(data []byte) error {
var s string
if err := json.Unmarshal(data, &s); err != nil {
return err
}
*ss = strings.Split(s, "-")
return nil
}
Dieser benutzerdefinierte Unmarshaler nimmt die JSON-Rohdaten als Eingabe und wandelt sie in ein Segment von Zeichenfolgen um, indem er sie am angegebenen Trennzeichen aufteilt (in diesem Fall „-“).
In unserem Original struct, wir können jetzt diesen benutzerdefinierten Typ für das Feld „Subjects“ verwenden:
type Student struct {
StudentNumber int `json:"student_number"`
Name string `json:"name"`
Subjects strslice `json:"subjects"`
}
Dadurch können wir die JSON-Daten direkt in die Struktur entpacken, wobei das Feld „Betreffs“ automatisch in einzelne Zeichenfolgen aufgeteilt wird:
json := `{"student_number":1234567, "name":"John Doe", "subjects":"Chemistry-Maths-History-Geography"}`
var s Student
if err := json.Unmarshal([]byte(json), &s); err != nil {
panic(err)
}
fmt.Println(s) // Output: {1234567 John Doe [Chemistry Maths History Geography]}
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3