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

最近都在經過完成一些列功能強化本身對經常使用api的熟悉。html

然而關於時間的api幾乎是最經常使用的api類型,因此總結一些經常使用的。python

 

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

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

 

獲取時間戳:api

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

output:
1488129589

 

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

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參數,因此要定義毫秒微妙啥的。。本身乘吧,通常本身定義一個時間用到毫秒之類的數據吧。spa

 

而後這裏重點說一下,格式化時間。。go這個格式化時間第一次我看到的時候是真的懵b了,先來看個例子設計

 

格式化時間:code

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格式。orm

 

字符串轉時間戳:

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時間戳和日期字符串的相互轉換

相關文章
相關標籤/搜索