
本文介绍如何使用 Go 标准库的 time.Parse 和 Time.Unix() 方法,将形如 "1/2/2006, 15:04:05" 的日期时间字符串安全、准确地解析并转换为自 1970-01-01 00:00:00 UTC 起经过的整数秒数。
本文介绍如何使用 go 标准库的 `time.parse` 和 `time.unix()` 方法,将形如 `"1/2/2006, 15:04:05"` 的日期时间字符串安全、准确地解析并转换为自 1970-01-01 00:00:00 utc 起经过的整数秒数。
在 Go 中,将日期时间字符串转换为 Unix 时间戳(单位:秒)是一个常见需求,例如用于日志分析、缓存过期控制或与 REST API 交互。核心步骤分为两步:解析字符串为 time.Time 类型,再调用 .Unix() 方法获取秒级时间戳。
✅ 正确做法:使用 time.Parse + Time.Unix()
Go 的 time.Parse 要求传入符合 Go 特色的参考时间格式(即著名的 Mon Jan 2 15:04:05 MST 2006,其数值 01/02/2006, 15:04:05 是格式模板,而非任意日期)。对于输入格式 "1/2/2006, 15:04:05",对应的标准布局字符串为:
const layout = "1/2/2006, 15:04:05"
⚠️ 注意:"1/2/2006" 中的 1 和 2 分别代表月中的第 1 天和一年中的第 2 个月(即 1 月 2 日),不是占位符;Go 通过这个固定参考值推断字段含义。因此该布局可正确解析 1/2/2006(1月2日)、12/25/2023(12月25日)等。
完整示例代码如下:
package main
import (
"fmt"
"log"
"time"
)
func main() {
const layout = "1/2/2006, 15:04:05"
input := "1/2/2006, 15:04:05"
t, err := time.Parse(layout, input)
if err != nil {
log.Fatal("解析失败:", err)
}
seconds := t.Unix() // 返回 int64 类型的 Unix 秒数
fmt.Printf("原始字符串: %s\n", input)
fmt.Printf("对应 Unix 时间戳(秒): %d\n", seconds)
fmt.Printf("对应时间(UTC): %s\n", t.UTC())
}输出:
原始字符串: 1/2/2006, 15:04:05 对应 Unix 时间戳(秒): 1136214245 对应时间(UTC): 2006-01-02 15:04:05 +0000 UTC
? 关键注意事项
- 时区处理:time.Parse 默认按本地时区解析。若需按 UTC 解析,请使用 time.ParseInLocation(layout, input, time.UTC);
- 错误必须检查:格式不匹配(如 "32/2/2006" 或 "1/2/06")会导致 err != nil,不可忽略;
- 纳秒精度丢失:.Unix() 仅返回秒数(截断小数部分);如需纳秒级时间戳,使用 .UnixNano();
- 布局字符串不可复用为普通日期:"1/2/2006" 是格式模板,不代表“只能解析 1 月 2 日”,它只是 Go 用来识别 month/day/year 字段顺序的锚点。
✅ 总结
Go 提供了简洁而严谨的时间解析机制:选定与输入格式严格匹配的 layout 字符串 → 调用 time.Parse 得到 time.Time → 调用 .Unix() 获取秒级时间戳。掌握这一流程,即可稳健处理各类日期时间字符串到 Unix 时间戳的转换任务。










