参考资料:
我试图弄清楚“方便的时间戳”在时间包装中的用途。
我可以使用其他常量(如RFC )很好地解析日期。
t, _ := time.Parse(time.RFC822, "02 Jan 06 15:04 MST")
fmt.Println(t.Unix())输出1136214240
vs
t, _ := time.Parse(time.Stamp, "Jan _2 15:04:05")
fmt.Println(t.Unix())产出:-62135596800
最后一个输出是错误的。我在这里错过了什么?这些时间戳有什么用?
下面是用于时间常数的Godoc:
const (
ANSIC = "Mon Jan _2 15:04:05 2006"
UnixDate = "Mon Jan _2 15:04:05 MST 2006"
RubyDate = "Mon Jan 02 15:04:05 -0700 2006"
RFC822 = "02 Jan 06 15:04 MST"
RFC822Z = "02 Jan 06 15:04 -0700" // RFC822 with numeric zone
RFC850 = "Monday, 02-Jan-06 15:04:05 MST"
RFC1123 = "Mon, 02 Jan 2006 15:04:05 MST"
RFC1123Z = "Mon, 02 Jan 2006 15:04:05 -0700" // RFC1123 with numeric zone
RFC3339 = "2006-01-02T15:04:05Z07:00"
RFC3339Nano = "2006-01-02T15:04:05.999999999Z07:00"
Kitchen = "3:04PM"
// Handy time stamps.
Stamp = "Jan _2 15:04:05"
StampMilli = "Jan _2 15:04:05.000"
StampMicro = "Jan _2 15:04:05.000000"
StampNano = "Jan _2 15:04:05.000000000"
)发布于 2014-01-30 19:42:06
最后一个输出是错误的。我在这里错过了什么?这些时间戳有什么用?
您肯定遗漏了一个错误检查,让我们添加它
t, err := time.Parse(time.Stamp, "Jan _2 15:04:05")
fmt.Println(err)
fmt.Println(t.Unix())输出:
解析时间"Jan _2 15:04:05“为"Jan _2 15:04:05":无法将"_2 15:04:05”解析为"_2“-62135596800
正确的字符串将是“Jan and 2 15:04:05”(注意Jan和2之间的双空格)。关于文档中的下划线:
在格式字符串中,下划线_表示一个空格,如果下列数字(一天)有两位数,则可以用数字替换该空格;以便与固定宽度的Unix时间格式兼容。
那么,为什么它表示为UNIX时间是负的,让我们检查:
t, err := time.Parse(time.Stamp, "Jan 2 15:04:05")
fmt.Println(err)
fmt.Println(t)输出:
<nil>
0000-01-02 15:04:05 +0000 UTC所以它是负的,因为今年是万。
最后,它能在哪里有用呢?例如,测量耗时操作的持续时间.您可以以一种邮票格式将当前时间输出到日志中,同时还可以输出一些消息,例如“开始执行”、“完成此操作”。然后,因为它是固定宽度的格式,而且没有不必要的年份信息,所以很容易读取日志,也很容易解析这些日志。
这种格式实际上在*nix中的"syslog“中使用。
https://stackoverflow.com/questions/21465082
复制相似问题