Démarrer les formats de date et d'heure incohérents
Lors du traitement des données JSON, la décompression des dates et heures peut entraîner des incohérences en raison des différents formats de décalage de fuseau horaire. Bien que le mécanisme d'analyse standard de Go attend des décalages de fuseau horaire au format 02h00, certaines données peuvent contenir des formats incorrects tels que 0200.
Pour résoudre ce problème, Go fournit une méthode de démarshaling personnalisée pour gérer les formats de fuseau horaire corrects et incorrects. Voici une approche révisée :
type MyTime struct { time.Time } func (self *MyTime) UnmarshalJSON(b []byte) (err error) { s := string(b) // Remove quotation marks s = s[1:len(s)-1] // Attempt to parse using RFC3339Nano format t, err := time.Parse(time.RFC3339Nano, s) if err != nil { // If parsing fails, try custom format without ':' t, err = time.Parse("2006-01-02T15:04:05.999999999Z0700", s) } self.Time = t return } type Test struct { Time MyTime `json:"time"` }
Dans cette méthode de démarshaling personnalisée (UnmarshalJSON), nous :
Cette approche garantit que les chaînes datetime correctes et mal formatées soient analysées correctement.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!