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

时间:2018-03-09 10:47:20

标签: parsing go time format

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

这是一个游乐场示例: 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

我怎样才能使它们平等?

1 个答案:

答案 0 :(得分:0)

区别在于日期的精确度。

您的time.Now()返回6位小数(微秒)的结果,并尝试格式化3位小数(毫秒)的时间。

你必须在毫秒时间内缩短你的时间:

t := time.Now().Round(time.Millisecond)