为什么时间格式和解析会给出不同的结果?

问题描述 投票:0回答:1

我正在占用当前时间并对其进行格式化并将其解析回来。当我将结果与当前时间进行比较时,它们并不相等。

这是一个游乐场的例子:https://play.golang.org/p/DDFzi1t8v_-

t := time.Now()
formatted := t.Format("2006-01-02 15:04:05.000 -0700")
parsed, _ := time.Parse("2006-01-02 15:04:05.000 -0700", formatted)
fmt.Println(parsed.Equal(t))

这是在操场上工作,但不是在我的本地计算机上,因为我的时区是+0300。

这是我的计算机上相同代码的输出:

t         :  2018-03-09 13:38:37.229832 +0300 +03 m=+0.000440904
formatted :  2018-03-09 13:38:37.229 +0300
parsed    :  2018-03-09 13:38:37.229 +0300 +03
false

我怎样才能使它们平等?

parsing go time format
1个回答
0
投票

不同之处在于日期的精确度。

你的time.Now()返回一个带有6位小数(微秒)的结果,你试着用3位小数(毫秒)格式化一个时间。

你需要在毫秒时间内完成你的时间:

t := time.Now().Round(time.Millisecond)
© www.soinside.com 2019 - 2024. All rights reserved.