一、问题描述

windows下,time.Parse()的时区和time.Format()的时区是一致的。
但是在linux环境下,time.Parse()的默认时区是UTCtime.Format()的时区默认是本地,两者如果不处理好就会导致错误。

  1. package main
  2. import "time"
  3. import "fmt"
  4. func main(){
  5. t, err := time.Parse("2006-01-02 15:04:05", "2017-12-03 22:01:02")
  6. if err != nil{
  7. fmt.Println(err)
  8. return
  9. }
  10. fmt.Println(t)
  11. fmt.Println(time.Now())
  12. fmt.Println(time.Now().Sub(t).Seconds())
  13. }

输出:

  1. 2017-12-03 22:01:02 +0000 UTC
  2. 2017-12-03 22:15:26.592204446 +0800 CST m=+0.003020091
  3. -27935.407549533

很明显能看到两者的时区不同并且如果把两者时间相减结果也不符合预期。

二、解决方法

使用time.ParseInLocation()而不是time.Parse()

  1. package main
  2. import "time"
  3. import "fmt"
  4. func main(){
  5. localTime, err := time.ParseInLocation("2006-01-02 15:04:05", "2017-12-03 22:01:02", time.Local)
  6. if err != nil{
  7. fmt.Println(err)
  8. return
  9. }
  10. fmt.Println(localTime)
  11. fmt.Println(time.Now())
  12. fmt.Println(time.Now().Sub(localTime).Seconds())
  13. }

结果:

  1. 2017-12-03 22:01:02 +0800 CST
  2. 2017-12-03 22:18:26.288174547 +0800 CST m=+0.001532618
  3. 1044.288357362