登录
首页 >  Golang >  Go问答

如何获取时间戳之间的差异(字符串或 time.time 之间)

来源:stackoverflow

时间:2024-04-12 19:09:36 158浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《如何获取时间戳之间的差异(字符串或 time.time 之间)》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

问题内容

我有一个问题:我需要知道 golang 中两个时间戳之间的差异/持续时间。因此,我使用时间库(https://golang.org/pkg/time/)。

如果我有两个“time.time”类型的时间戳,则可以使用“time.Sub()”轻松获得差异。我的问题是我的时间戳之一来自另一个函数,并且只能将其作为字符串传输:

t1 := "2009-11-10 23:00:00 +0000 UTC m=+0.000000001" //类型:字符串 t2 := time.Now() //类型:time.time

现在我有基本的可能性:

A) 将 t2 也转换为字符串,并尝试找出两个字符串之间的差异 (UGLY)

B) 将 t1 从“string”类型转换为“time.time”类型,然后应用“time.Sub()”

我想走B)路。因此,我发现

time.Parse(格式,时间字符串)

应该可以做到。所以我尝试使用转换 t1

t1_time, err := time.Parse(time.RFC3339, t1)

但是结果并没有达到预期!相反,我得到了这个

0001-01-01 00:00:00 +0000 世界标准时间

并且错误说“错误解析时间”2009-11-10 23:00:02 +0000 UTC m=+2.000000001”为“2006-01-02T15:04:05Z07:00”:无法解析“23: 00:02 +0000 UTC m=+2.000000001" 为 "T" "。

如果我使用自己的时间格式,与 t1 相同

时间格式 := "2009-11-10 23:00:00 +0000 UTC m=+0.000000001" t1_time, err := time.Parse(timeformat , t1)

结果仍然错误,我收到错误消息“错误解析时间”2009-11-10 23:00:02 +0000 UTC m=+2.000000001”为“2009-11-10 23:00:00 +0000” UTC m=+0.000000001”:无法将“9-11-10 23:00:02 +0000 UTC m=+2.000000001”解析为“009-”“。

我也尝试过 UNIX 时间,但时间库不允许我将字符串转换为 UNIX。

我做错了什么??为什么解析不起作用?感谢您的帮助!


解决方案


基本上你想要:

t1_raw := "2009-11-10 23:00:00 +0000 UTC m=+0.000000001"
    format := "2006-01-02 15:04:05 -0700 MST"

    // for simplicity t1_raw[:29] discards time's monotonic delta
    // i.e. the " m=+0.000000001" suffix

    t1, err := time.Parse(format, t1_raw[:29])
    if err != nil {
            log.Fatal(err)
    }

    log.Println("Duration ->", t2.Sub(t1))

如果您确实想要包含单调增量,则必须手动解析该数字并将增量应用于 t1

演示version

注意:演示版本将显示零持续时间 - 因为演示的时钟从 nov 11 2009 开始 - go 的重要生日。

以上就是《如何获取时间戳之间的差异(字符串或 time.time 之间)》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>