由于来自 Bigquery 数据库的查询响应,我必须使用 Civil.Datetime。

如何从 Golang 中的 Civil.Datetime 获取 time.Time 日期?

就像是:

var date time.Time = civil.ToTime(myCivilTime)

我检查了民用时间文档:https://godoc.org/cloud.google.com/go/civil 并且有一个函数似乎可以满足我的要求。
func (d Date) In(loc *time.Location) time.Time

但我不确定我应该如何设置 *time.Location 参数。

最佳答案

使用对您的应用程序有意义的任何 time.Location。例如,

package main

import (
    "fmt"
    "time"

    "cloud.google.com/go/civil"
)

func main() {
    now := time.Now().Round(0)
    fmt.Println(now, " : time Now")
    d := civil.DateTimeOf(now)
    fmt.Println(d, "           : civil DateTime")
    t := d.In(time.UTC)
    fmt.Println(t, " : time UTC")
    t = d.In(time.Local)
    fmt.Println(t, " : time Local")
    pacific, err := time.LoadLocation("America/Los_Angeles")
    if err != nil {
        fmt.Println(err)
        return
    }
    t = d.In(pacific)
    fmt.Println(t, " : time Pacific")
}

输出:
2018-07-03 12:46:15.728611385 -0400 EDT  : time Now
2018-07-03T12:46:15.728611385            : civil DateTime
2018-07-03 12:46:15.728611385 +0000 UTC  : time UTC
2018-07-03 12:46:15.728611385 -0400 EDT  : time Local
2018-07-03 12:46:15.728611385 -0700 PDT  : time Pacific

关于date - 如何从civil.Datetime获取time.Time,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51157052/

10-13 07:15