一、問題描述
在windows下,time.Parse()的時(shí)區(qū)和time.Format()的時(shí)區(qū)是一致的。
但是在linux環(huán)境下,time.Parse()的默認(rèn)時(shí)區(qū)是UTC,time.Format()的時(shí)區(qū)默認(rèn)是本地,兩者如果不處理好就會(huì)導(dǎo)致錯(cuò)誤。
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
很明顯能看到兩者的時(shí)區(qū)不同并且如果把兩者時(shí)間相減結(jié)果也不符合預(yù)期。
二、解決方法
使用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())
}
結(jié)果:
2017-12-03 22:01:02 +0800 CST
2017-12-03 22:18:26.288174547 +0800 CST m=+0.001532618
1044.288357362
補(bǔ)充:最自戀的golang的time.Format的坑
我想格式化輸出日期
fmt.
Println
(time.
Now
().
Format
(
"2010-10-10 15:04:05"
))
結(jié)果輸出了
9060-60-60 11:11:36
這什么鬼
百度了一個(gè)
fmt.
Println
(time.
Now
().
Format
(
"2006-01-02 15:04:05"
))
這就輸出正確了
2017-06-09 11:12:39
為什么呢,沒有問題什么,因?yàn)間o語言最自戀最賤,據(jù)說那個(gè)日期是GO語言的誕生時(shí)間,一定要用這個(gè)日期格式化
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- golang 定時(shí)任務(wù)方面time.Sleep和time.Tick的優(yōu)劣對比分析
- 解決golang時(shí)間字符串轉(zhuǎn)time.Time的坑
- golang的時(shí)區(qū)和神奇的time.Parse的使用方法
- 對Golang中的runtime.Caller使用說明
- Golang中的time.Duration類型用法說明
- golang time包做時(shí)間轉(zhuǎn)換操作
- golang xorm及time.Time自定義解決json日期格式的問題
- golang time常用方法詳解