Golang的時間生成,格式化,以及獲取函數執行時間的方法


最近都在通過完成一些列功能強化自己對常用api的熟悉。

然而關於時間的api幾乎是最常用的api類型,所以總結一些常用的。

 

以YY-mm-dd HH:MM:SS.9位 輸出當前時間:

func main() {
    fmt.Println(time.Now())
}
output:
2017-02-27 01:20:00.567634365 +0800 CST

 

獲取時間戳:

func main() {
    fmt.Println(time.Now().Unix())
}

output:
1488129589

 

給定一個時間戳,返回一個標准datetime時間:

func main() {
    timestamp := time.Now().Unix()
    fmt.Println(time.Unix(timestamp, 0))
}

output:
2017-02-27 01:18:07 +0800 CST

 

指定一個時間:

func main() {
    fmt.Println(time.Date(2017, 02, 27, 20, 20, 20, 20, time.Local))
}

output:
2017-02-27 20:20:20.00000002 +0800 CST

這里注意,Date初始化的時候最后一個參數,傳的是一個地區struct,可以直接引用time包給我提供現成的utc時區,也可以用local本地計算機的。由於直接給了nsec參數,所以要定義毫秒微妙啥的。。自己乘吧,一般自己定義一個時間用到毫秒之類的數據吧。

 

然后這里重點說一下,格式化時間。。go這個格式化時間第一次我看到的時候是真的懵b了,先來看個例子

 

格式化時間:

x := time.Date(2017, 02, 27, 17, 30, 20, 20, time.Local)
fmt.Println(x.Format("2006-01-02 15:04:05"))

output:
2017-02-27 17:30:20

看上去是不是有點懵? 2006-01-02 15:04:05這個每組數字都是有獨特的含義的,就是相當於拿一段數字來代替了我們其他語言常用的YY:mm:ss HH-MM-SS 這樣。但是其實習慣之后發現這個設計還蠻好記的,直接記12345就好了。3那個位置的數這里我使用的15,也就是用24小時格式來顯示,如果直接寫03則是12小時am pm格式。

 

字符串轉時間戳:

func main() {
    x := "2017-02-27 17:30:20"
    p, _ := time.Parse("2006-01-02 15:04:05", x)
    fmt.Println(p.Unix())
}

output:
1488216620

 

字符串轉時間(其實使用time.Parse轉回來就是和字符串相同的格式了)

func main() {
    x := "2017-02-27 17:30:20"
    p, _ := time.Parse("2006-01-02 15:04:05", x)
    fmt.Println(p)
}

output:
2017-02-27 17:30:20 +0000 UTC

其他還有很多類似After(), Before()等的api 用來判各種,但是平時用得最多的應該就是上面的類型api了,其實多用幾次也就熟悉了。

 

另外額外說一下,我還沒有來得及在golang里面查找在python中類似time.timit的庫,但是我注意到time模塊也提供這個查看運行時間的方法,而且還異常方便,只需要在函數執行的最開始取一個當前時間,然后將其作參數傳給time.Since(time.Time)就可以獲得運行時間了。非常方便。但是沒有找到支持多次運行,或者repeat之類的參數支持,回頭再看看吧上個例子:

func main() {
    t1 := time.Now()

    x := "2017-02-27 17:30:20"
    p, _ := time.Parse("2006-01-02 15:04:05", x)
    fmt.Println(p)

    elapsed := time.Since(t1)
    fmt.Println("App elapsed: ", elapsed)
}

outside:
2017-02-27 17:30:20 +0000 UTC
App elapsed:  51.044µs

 

 

Reference:

https://golang.org/src/time/example_test.go  example_test_for_time

http://www.cnblogs.com/baiyuxiong/p/4349595.html  Go時間戳和日期字符串的相互轉換

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM