我在postgres表中有日期。日期与UTC时区一起存储。
来自python的示例。
roster = Roster.objects.get(id=266438)
roster.start_timestamp
Out[11]: datetime.datetime(2018, 9, 7, 15, 0, tzinfo=<UTC>)
当我从go lib / pq中编组这些日期时,将以某种方式应用本地时区。
func (nt *pq.NullTime) MarshalJSON() ([]byte, error) {
if !nt.Valid {
return []byte("\"\""), nil
}
val := fmt.Sprintf("\"%s\"", nt.Time.Format("01/02/2006 15:04:05"))
fmt.Println("Marshalling FMPDateTime", nt, val)
return []byte(val), nil
}
示例日志:
Marshalling DateTime &{2018-09-08 00:30:00 +0930 ACST true} "09/08/2018 00:30:00"
2018-09-08 00:30:00 +0930 ACST 是 2018-09-07 15:00:00 UTC。
您如何以UTC而不是本地时区JSON Marshall pq.NullTime?
答案 0 :(得分:1)
图书馆通常使用本地时区构造time.Time
值,但是时刻仍然相同,因此您不必为此担心。
如果要特别显示/输出UTC时区,则将时间“切换”到UTC时区。为此,您可以使用Time.UTC()
方法:
val := fmt.Sprintf("\"%s\"", nt.Time.UTC().Format("01/02/2006 15:04:05"))
仅此而已。
还要注意,如果您的NullTime
无效,我宁愿输出JSON null
而不是空字符串。