Go中time.Parse使用固定参考时间“Mon Jan 2 15:04:05 MST 2006”作为layout模板,各字段对应周几、月份、日期、24小时制小时、分钟、秒、时区和年份,需严格按位置匹配;解析时须注意时区处理与错误检查。

在 Go 中用 time.Parse 解析时间字符串,关键不是记格式,而是理解 Go 独特的参考时间(Reference Time)——Mon Jan 2 15:04:05 MST 2006。这个固定时间串就是所有 layout 字符串的模板。
为什么必须用“Mon Jan 2 15:04:05 MST 2006”?
Go 不像其他语言用占位符(如 %Y-%m-%d),而是用一个真实、具体的例子作为布局参照。它的每个部分对应一个时间单位:
- Mon → 周几英文缩写(Monday → Mon)
- Jan → 月份英文缩写(January → Jan)
- 2 → 日期(不是 02;1–31 范围内不补零)
- 15 → 小时(24 小时制;13–24,不是 03)
- 04 → 分钟(始终两位,00–59)
- 05 → 秒(始终两位,00–59)
- MST → 时区缩写(如 PST、CST、UTC,注意大小写)
- 2006 → 四位年份
常见时间格式对应的 layout 示例
直接照着参考时间改写你的时间字符串结构即可:
-
"2006-01-02 15:04:05" →
"2006-01-02 15:04:05"(标准 ISO 格式,无时区) -
"2006/01/02" →
"2006/01/02" -
"02-Jan-2006 15:04:05 MST" →
"02-Jan-2006 15:04:05 MST" -
"2006-01-02T15:04:05Z" →
"2006-01-02T15:04:05Z"(RFC3339 子集,Z 表示 UTC) -
"2006-01-02 15:04:05 -0700" →
"2006-01-02 15:04:05 -0700"(带数字时区偏移)
解析时要注意时区和错误处理
time.Parse 默认使用本地时区解析,除非 layout 中明确包含时区信息(如 Z、MST 或 -0700)。建议显式指定时区或用 time.ParseInLocation 控制上下文:
立即学习“go语言免费学习笔记(深入)”;
- 想按 UTC 解析?用
time.ParseInLocation(layout, value, time.UTC) - 想按北京时间(CST)解析?可用
time.LoadLocation("Asia/Shanghai")获取 location 后传入 - 务必检查返回的
error:格式错、时区无效、日期非法(如 2023-02-30)都会失败
小技巧:快速生成 layout 的方法
如果手写 layout 容易出错,可以反向操作:先用 time.Now() 打印出目标格式,再把值替换成参考时间字段:
- 比如你想解析
"23/04/2024 10:30:45",就写:fmt.Println(time.Now().Format("06/01/2006 15:04:05"))→ 得到类似"24/04/2024 10:30:45",然后把数字替成参考时间对应值:"02/01/2006 15:04:05"→ 实际 layout 是"02/01/2006 15:04:05" - 注意:日/月顺序要严格对应原始字符串中位置,
02永远是日,01永远是月
基本上就这些。记不住 layout?贴一张参考时间图在编辑器边栏,比背文档快得多。










