1 回答

TA贡献1942条经验 获得超3个赞
使用time包
如果持续时间少于一天,您可以简单地将其添加到具有零时间部分的参考时间戳,然后使用适当的布局格式化时间。
参考时间可以是零值time.Time或unix参考时间。
例如:
ms := int64(65104)
var t time.Time // Zero time
t = t.Add(time.Duration(ms) * time.Millisecond)
fmt.Println(t.Format("15:04:05,000"))
t = time.UnixMilli(ms)
fmt.Println(t.Format("15:04:05,000"))
这将输出(在Go Playground上尝试):
00:01:05,104
00:01:05,104
如果您想处理超过一天的持续时间,则此解决方案不适合。一个可能的解决办法是自己计算小时,其余的(分、秒、毫秒)用上面的方法。
例如:
const msInHour = 60 * 60 * 1000
func format(ms int64) string {
hours := ms / msInHour
ms = ms % msInHour
t := time.UnixMilli(ms)
return fmt.Sprintf("%02d:%s", hours, t.Format("04:05,000"))
}
测试它:
fmt.Println(format(65104))
fmt.Println(format(27*60*60*1000 + 65104))
这将输出(在Go Playground上尝试):
00:01:05,104
27:01:05,104
推出自己的解决方案
如果你不想使用time包,你可以自己做。该算法只是除法和余数。例如,毫秒部分是除以 1000 后的余数。此后的秒数是除以 60 后的余数,依此类推。
例如:
func format(n int64) string {
ms := n % 1000
n /= 1000
sec := n % 60
n /= 60
min := n % 60
n = n / 60
return fmt.Sprintf("%02d:%02d:%02d,%03d", n, min, sec, ms)
}
这也处理超过一天的持续时间。测试它:
fmt.Println(format(65104))
fmt.Println(format(27*60*60*1000 + 65104))
这将输出(在Go Playground上尝试):
00:01:05,104
27:01:05,104
- 1 回答
- 0 关注
- 143 浏览
添加回答
举报