Démarrer une date/heure mal formatée
Arrière-plan
Lors de la tentative d'analyse d'une chaîne datetime dans Go en utilisant time.Parse, il peut échouer si le décalage du fuseau horaire est mal formaté. Plus précisément, si le décalage est spécifié comme " 0200 " au lieu de " 02:00 ", comme l'exige la RFC3339.
Question
Étant donné un ensemble de fichiers JSON contenant les dates et heures avec un format de décalage incorrect, comment pouvons-nous les désorganiser correctement dans Go sans modifier le format des dates et heures marshalées en JSON ?
Réponse
Heure personnalisée Champ
Pour gérer les formats de décalage valides et invalides, nous pouvons définir notre propre type de champ temporel personnalisé. Cela nous permet de remplacer le comportement de démarshal par défaut et d'analyser manuellement la chaîne datetime selon l'un des deux formats attendus.
Exemple de mise en œuvre
<code class="go">type MyTime struct { time.Time } func (self *MyTime) UnmarshalJSON(b []byte) (err error) { s := string(b) // Remove quotes from JSON string (optional) s = s[1:len(s)-1] t, err := time.Parse(time.RFC3339Nano, s) if err != nil { t, err = time.Parse("2006-01-02T15:04:05.999999999Z0700", s) } self.Time = t return } type Test struct { Time MyTime `json:"time"` }</code>
Dans cet exemple , nous utilisons la méthode UnmarshalJSON pour remplacer le comportement de démarshaling par défaut. Nous supprimons d’abord tous les guillemets entourant la chaîne datetime, puis essayons de l’analyser en utilisant le format standard time.RFC3339Nano. Si cela échoue, nous essayons également d'analyser le format incorrect ("2006-01-02T15:04:05.999999999Z0700").
Format RFC3339Nano dans les métadonnées JSON
Pour préciser l'utilisation du format RFC3339Nano pour le champ horaire personnalisé en JSON, on peut simplement utiliser la même chaîne de format que dans la méthode UnmarshalJSON :
<code class="go">type Test struct { Time MyTime `json:"time,omitempty"` }</code>
Cela indique que le champ horaire sera représenté dans JSON sous forme de chaîne au format RFC3339Nano. Lors du marshalage vers JSON, la méthode MarshalJSON remplacée du type MyTime sera utilisée pour garantir que le format correct est conservé.
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!