![](/img/trans.png)
[英]how to display python time.time() stored as a float in bigquery as a datetime?
[英]time.Time Round to Day
我有一個時間戳進來,我想知道是否有辦法將它舍入到 PST 一天的開始。 例如, ts: 1305861602
對應於2016-04-14, 21:10:27 -0700
,但我想將其四舍五入為映射到2016-04-14 00:00:00 -0700
的時間戳。 我通讀了 time.Time 文檔,但沒有找到辦法。
執行此操作的簡單方法是使用前一個Time
創建新Time
,並僅分配年月和日。 它看起來像這樣;
rounded := time.Date(toRound.Year(), toRound.Month(), toRound.Day(), 0, 0, 0, 0, toRound.Location())
這是一個播放示例; https://play.golang.org/p/jnFuZxruKm
您可以簡單地使用持續時間24 * time.Hour
來截斷時間。
t := time.Date(2015, 4, 2, 0, 15, 30, 918273645, time.UTC)
d := 24 * time.Hour
t.Truncate(d)
我相信最簡單的方法是創建一個新日期,如本答案所示。 但是,如果您想使用 time.Truncate,則有兩種不同的情況。
var testUtcTime = time.Date(2016, 4, 14, 21, 10, 27, 0, time.UTC)
// outputs 2016-04-14T00:00:00Z
fmt.Println(testUtcTime.Truncate(time.Hour * 24).Format(time.RFC3339))
var testTime = time.Date(2016, 4, 14, 21, 10, 27, 0, time.FixedZone("my zone", -7*3600))
// this is wrong (outputs 2016-04-14T17:00:00-07:00)
fmt.Println(testTime.Truncate(time.Hour * 24).Format(time.RFC3339))
// this is correct (outputs 2016-04-14T00:00:00-07:00)
fmt.Println(testTime.Add(-7 * 3600 * time.Second).Truncate(time.Hour * 24).Add(7 * 3600 * time.Second).Format(time.RFC3339))
除了粘性的答案以獲得本地Truncate
還可以這樣做
t := time.Date(2015, 4, 2, 0, 15, 30, 918273645, time.Local)
d := 24 * time.Hour
fmt.Println("in UTC", t.Truncate(d))
_, dif := t.Zone()
fmt.Println("in Local", t.Truncate(24 * time.Hour).Add(time.Second * time.Duration(-dif)))
func truncateToDay(t time.Time) {
nt, _ := time.Parse("2006-01-02", t.Format("2006-01-02"))
fmt.Println(nt)
}
這不優雅,但有效。
我在所有項目中使用這些功能:
package time_utils
import "time"
func TruncateToStartOfDay(t time.Time) time.Time {
return time.Date(t.Year(), t.Month(), t.Day(), 0, 0, 0, 0, t.Location())
}
func TruncateToEndOfDay(t time.Time) time.Time {
return time.Date(t.Year(), t.Month(), t.Day(), 23, 59, 59, 0, t.Location())
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.