Lorsque vous travaillez avec des horodatages, il est courant de rencontrer des formats autres que l'horodatage d'époque Unix standard. Par exemple, tar produit des horodatages au format 2011-01-19 22:15. Pour analyser ces horodatages dans Go, nous nous tournons vers la fonction time.Parse.
Cependant, il suffit d'appeler time.Parse("2011-01-19 22:15", "2011-01-19 22:15 ") entraînera une erreur : "heure d'analyse 19/01/2011 22h15 : mois hors plage". Pour comprendre pourquoi, nous devons nous plonger dans l'API non conventionnelle de la fonction time.Parse.
Les bizarreries de la chaîne de formatage
La fonction time.Parse nécessite une chaîne de formatage qui spécifie comment interpréter l'horodatage d'entrée. Pour nos besoins, utilisons le format 2006-01-02 15:04. Cette chaîne suit les conventions énoncées dans la documentation du package d'heure Go :
À définir notre propre format, il nous suffit de préciser comment les éléments du format standard apparaîtraient dans notre format personnalisé. Par exemple, dans notre cas, le format résultant serait 2006-01-02 15:04.
Analyse de l'horodatage
Avec notre chaîne de formatage en place, nous peut maintenant analyser l'horodatage :
import "time" func main() { t, err := time.Parse("2006-01-02 15:04", "2011-01-19 22:15") if err != nil { fmt.Println(err) return } fmt.Println(t) }
Cela analysera correctement l'horodatage et affichera le objet time.Time résultant.
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!