Go での文字列分割によるカスタム アンマーシャル
JSON データを扱う場合、特定のデータに合わせてアンマーシャリング プロセスを変換またはカスタマイズする必要が生じることがよくあります。データ型。この場合、アンマーシャリング中にカンマ区切りの値を含む JSON 文字列を []string スライスに分割したいと考えています。
これを実現するには、[]string 型のカスタム アンマーシャラーを実装しましょう。
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
}
このカスタム アンマーシャラーは、生の JSON データを入力として受け取り、指定された区切り文字 (この場合は「-」) で分割して文字列のスライスに変換します。
オリジナルではstruct、このカスタム タイプを Subjects フィールドに使用できるようになりました:
type Student struct {
StudentNumber int `json:"student_number"`
Name string `json:"name"`
Subjects strslice `json:"subjects"`
}
これにより、JSON データを構造体に直接アンマーシャリングできるようになり、件名フィールドが自動的に個別の文字列に分割されます:
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]}
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3