内容简介:作为原Python开发,对Golang的日期时间格式化非常不适应。网上使用的格式化字符串例子大部分是这样的:这样就可以说出格式化的时间字符串了。Golang用了和前面的例子唯一不同的是换了年份,但是这次的输出是:
作为原 Python 开发,对Golang的日期时间格式化非常不适应。网上使用的格式化字符串例子大部分是这样的:
import ( "fmt" "time" ) func main() { fmt.Println(time.Now().Format("2006-01-02 15:04:05")) }
这样就可以说出格式化的时间字符串了。Golang用了 2006-01-02 15:04:05
这种写死时间来分辨时间格式,然后喜欢自由发挥的我自然就会这样加一句:
fmt.Println(time.Now().Format("2020-01-02 15:04:05"))
和前面的例子唯一不同的是换了年份,但是这次的输出是:
❯ go run simple.go 2020-07-05 09:38:45 5050-07-05 09:38:45
啊!下面的那个结果是错误的了。难道我只能用那个魔法字符串格式 2006-01-02 15:04:05
嘛?
带着这个问题开始寻找答案,首先从SO上找到了对这个时间的解释(就在src/time/format.go头部注释处):
// The reference time used in the layouts is the specific time: // Mon Jan 2 15:04:05 MST 2006 // which is Unix time 1136239445. Since MST is GMT-0700, // the reference time can be thought of as // 01/02 03:04:05PM '06 -0700
也就是说,这个时间按代表的部分拆开,其实可以理解为一个递增序列(01 02 03 04 05 06 07)
先感叹下语言设计者的用心: 2006-01-02 15:04:05
这个日期,不但挺好记的,而且用起来也比较方便。
那么问题2也出现了
为什么用下午三点而不是上午三点?
我盲猜是因为下午时间不能区分,所以写一段代码测试一下:
t, _ := time.Parse("2006-01-02 15:04:05", "2006-01-02 03:04:05") fmt.Println(t) fmt.Println(t.Format("2006-01-02 03:04:05")) fmt.Println(t.Format("2006-01-02 15:04:05")) t, _ = time.Parse("2006-01-02 15:04:05", "2006-01-02 15:04:05") fmt.Println(t) fmt.Println(t.Format("2006-01-02 03:04:05")) fmt.Println(t.Format("2006-01-02 15:04:05"))
这段代码分别把时间指向了 2006-01-02 03:04:05
和 2006-01-02 15:04:05
,然后格式化。看看输出:
❯ go run simple.go 2006-01-02 03:04:05 +0000 UTC 2006-01-02 03:04:05 2006-01-02 03:04:05 2006-01-02 15:04:05 +0000 UTC 2006-01-02 03:04:05 2006-01-02 15:04:05
看到第二个例子了吧?这个是一个下午时间,但使用 2006-01-02 03:04:05
和 2006-01-02 15:04:05
格式化获得的时间是不一样的。所以可以看出一定要使用24小时制的时间。
延伸阅读
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- oracle 日期格式化(yyyymmdd)及常规日期计算大全
- PostgreSQL格式化与日期函数
- Java 日期时间格式化转换符
- SpringBoot(十一):LocalDateTime格式化日期
- [译]Python 中如何格式化日期
- ASP常用日期格式化函数 FormatDate()
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Linux二进制分析
[美]瑞安 奥尼尔 / 棣琦 / 人民邮电出版社 / 2017-12-1 / CNY 59.00
二进制分析属于信息安全业界逆向工程中的一种技术,通过利用可执行的机器代码(二进制)来分析应用程序的控制结构和运行方式,有助于信息安全从业人员更好地分析各种漏洞、病毒以及恶意软件,从而找到相应的解决方案。 本书是一本剖析Linux ELF工作机制的图书,共分为9章,其内容涵盖了Linux环境和相关工具、ELF二进制格式、Linux进程追踪、ELF病毒技术、Linux二进制保护、Linux中的E......一起来看看 《Linux二进制分析》 这本书的介绍吧!