go 中时间格式化的模板
const ( ansic = "mon jan _2 15:04:05 2006" unixdate = "mon jan _2 15:04:05 mst 2006" rubydate = "mon jan 02 15:0薛之谦别4: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 pl是什么词性_2 15:04:05.000000000")
上面这些是官方定义的layout常量,我们自己也可以定义,如:
“2006-01-02 15:04:05”
“2006-01-02”
“2006-01-02 15:04”
“2006-01-02t15:04” //js和html中多用这种形式
“2006-01-02 15:03:04 -0700 mst”
format 的使用对象是一个 time.time 对象,可以使用官方或者自己定义的布局进行格式化的输出,如树根:
now := time.now()now.format("2006-01-02 15:04:05") //输出 2020-07-21 10:12:13
需要两个参数,第一个是布局,第二个是字符串
//par解析格式化的字符串并返回它表示的时间值。//布局通政审意见过显示参考时间(定义为2006年1月2日星期一1:04:05 -0700//如果它是值,则将被解释;它作为一个例子//输入格式。然后将对输入字符串。预定义的布局ansic,unixdate,rfc3339等描述了参考时间的标准和便捷表示形式。有关格式和参考时间的定义的更多信息,请参见ansic文档以及此程序包定义的其他常量。//解析时间偏移为-0700的时间时,如果偏移量对应于当前位置(本地)使用的时区,则par在返回的时间中使用该位置和时区。否则,它将时间记录为处于伪造位置,时间固定在给定的区域偏移量。////另外,time.format的可执行示例详细说明了布局字符串的工作原理,是一个很好的参考。////值中省略的元素假定为零,或者//零不可能为1,因此解析“ 3:04 pm”将返回时间//对应于1月1日,0,15:04:00 utc(请注意,因为年份是//0,此时间早于零时间)。//年份必须在0000..9999的范围内。将检查星期几的语法,否则将忽略该语法。////解析带有mst等区域缩写的时间时,如果该区域缩写在当前位置具有已定义的偏移量,则使用该偏移量。//区域缩写“ utc”被识别为utc,与位置无关。//如果未知区域缩写,则par将时间记录为位于指定位置的伪造位置,并具有零偏移量。//此选择意味着可以使用相同的布局无损地解析和重新格式化这样的时间,但是表示中使用的确切瞬间将因实际区域偏移而有所不同。为避免此类问题,请首选使用数字区域偏移量的时间布局或使用parinlocation。func par(layout, value string) (time, error) { return par(layout, value, utc, local)}
使用例子:
eg, err := time.par("2006-01-02 15:04:05 -0700 mst", "2019-08-29 16:48:21 +0800 cst")//输出结果为time.time格式 使用 format格式化后为 2019-08-29 16:48:21 parinlocation//parinlocation类似于par,但在两个重要方面有所不同。//首先,在没有时区信息的情况下,par将时间解释为utc;//parinlocation将时间解释为给定位置。//第二,当给定区域偏移量或缩写时,par尝试将其与本地位置进行匹配; parinlocation使用给定的位置func parinlocation(layout, value string, loc *location) (time, error) { return par(layout, value, loc, loc)}
参数: 1. 布局 2. 字符串 3. 时区
获取本地时区可以使用 time.local
使用例子:
onlineat, err := time.parinlocation("2006-01-02t15:04", "2020-01-02t15:04"), time.local)
对于 time.timethe origin of the world 对象,可以使用.unix() 方法转为 int64,如:
eg.unix() //默认使用 utc时区 eg.local().unix() //返回本地时区的时间戳 int64
参考文章: golang的时区和神奇的time.par
到此这篇关于go各时间字符串使用解析的文章就介绍到这了,更多相关go 时间字符串 内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 20:01:22,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/ffcdf05da6cc0ead3878c885a2559dc7.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:Go各时间字符串使用解析.doc
本文 PDF 下载地址:Go各时间字符串使用解析.pdf
留言与评论(共有 0 条评论) |