一、问题描述
在windows下,time.Parse()的时区和time.Format()的时区是一致的。
但是在linux环境下,time.Parse()的默认时区是UTC,time.Format()的时区默认是本地,两者如果不处理好就会导致错误。
package main
import "time"
import "fmt"
func main(){
t, err := time.Parse("2006-01-02 15:04:05", "2017-12-03 22:01:02")
if err != nil{
fmt.Println(err)
return
}
fmt.Println(t)
fmt.Println(time.Now())
fmt.Println(time.Now().Sub(t).Seconds())
}
输出:
2017-12-03 22:01:02 +0000 UTC
2017-12-03 22:15:26.592204446 +0800 CST m=+0.003020091
-27935.407549533
很明显能看到两者的时区不同并且如果把两者时间相减结果也不符合预期。
二、解决方法
使用time.ParseInLocation()而不是time.Parse():
package main
import "time"
import "fmt"
func main(){
localTime, err := time.ParseInLocation("2006-01-02 15:04:05", "2017-12-03 22:01:02", time.Local)
if err != nil{
fmt.Println(err)
return
}
fmt.Println(localTime)
fmt.Println(time.Now())
fmt.Println(time.Now().Sub(localTime).Seconds())
}
结果:
2017-12-03 22:01:02 +0800 CST
2017-12-03 22:18:26.288174547 +0800 CST m=+0.001532618
1044.288357362
补充:最自恋的golang的time.Format的坑
我想格式化输出日期
fmt.
Println
(time.
Now
().
Format
(
"2010-10-10 15:04:05"
))
结果输出了
9060-60-60 11:11:36
这什么鬼
百度了一个
fmt.
Println
(time.
Now
().
Format
(
"2006-01-02 15:04:05"
))
这就输出正确了
2017-06-09 11:12:39
为什么呢,没有问题什么,因为go语言最自恋最贱,据说那个日期是GO语言的诞生时间,一定要用这个日期格式化
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
您可能感兴趣的文章:- golang 定时任务方面time.Sleep和time.Tick的优劣对比分析
- 解决golang时间字符串转time.Time的坑
- golang的时区和神奇的time.Parse的使用方法
- 对Golang中的runtime.Caller使用说明
- Golang中的time.Duration类型用法说明
- golang time包做时间转换操作
- golang xorm及time.Time自定义解决json日期格式的问题
- golang time常用方法详解