主頁 > 知識庫 > golang時間、時區(qū)、格式的使用方法

golang時間、時區(qū)、格式的使用方法

熱門標簽:江西轉(zhuǎn)化率高的羿智云外呼系統(tǒng) 學海導(dǎo)航地圖標注 廣州呼叫中心外呼系統(tǒng) 中國地圖標注省會高清 地圖標注的汽車標 高德地圖標注口訣 南通如皋申請開通400電話 西部云谷一期地圖標注 浙江高速公路地圖標注

前幾天,因為需要實現(xiàn)海外服務(wù)端定時停機,涉及到時區(qū)的概念。網(wǎng)上搜索了一下,大部分都是談time.Format中的Layout,非常不成體系,這里就簡單總結(jié)一下其中的時間初始化、時區(qū)轉(zhuǎn)化及格式轉(zhuǎn)換。

開發(fā)中,我們對時間的使用是比較多的,其應(yīng)用場景,按照使用概率,從大到小,通常是:

  1. 獲取當前或數(shù)據(jù)庫中存儲的時間
  2. 比較兩個時間點的先后
  3. 顯示打印時間
  4. 時區(qū)轉(zhuǎn)換

對應(yīng)到go,也就是幾個基本定義:

  1. 時間點與時間段:Time,Duration。好比MVC中的M。
  2. 時 區(qū):Location,在時間轉(zhuǎn)換上,好比是MVC中的C。
  3. 格式化:Format的layout定義,好比MVC中的V。

單獨就Duration沒什么好談的,使用非常簡單。Time實例中的Add、Sub與其相關(guān),非常容易上手,就不再多說。

時區(qū)

時區(qū)是時間運算非常重要的概念,特別強調(diào)與layout是兩個完全不同的概念。go語言通過Location來作為時區(qū)的運行實例,同一時刻轉(zhuǎn)換成為不同的時區(qū),就需要通過不同的Location來進行。默認情況下,采用UTC(unix標準時間),而不是過去式的GMT(格林尼治標準時間)。

以下代碼展示了UTC標準、北京、美國洛杉磯在同一時刻的轉(zhuǎn)換:

  now := time.Now()
  local1, err1 := time.LoadLocation("") //等同于"UTC"
  if err1 != nil {
    fmt.Println(err1)
  }
  local2, err2 := time.LoadLocation("Local")//服務(wù)器設(shè)置的時區(qū)
  if err2 != nil {
    fmt.Println(err2)
  }
  local3, err3 := time.LoadLocation("America/Los_Angeles")
  if err3 != nil {
    fmt.Println(err3)
  }

  fmt.Println(now.In(local1))
  fmt.Println(now.In(local2))
  fmt.Println(now.In(local3))
  //output:
  //2016-12-04 07:39:06.270473069 +0000 UTC
  //2016-12-04 15:39:06.270473069 +0800 CST
  //2016-12-03 23:39:06.270473069 -0800 PST

代碼中,LoadLocation的輸入?yún)?shù)的取值,除了該函數(shù)的源代碼中可看到的”UTC”、”Local”,其余的值其實是遵照“IANA Time Zone”的規(guī)則,可以解壓$GOROOT/lib/time/zoneinfo.zip 這個文件打開查看。在Asia這個目錄,我看到了Chongqing,Hong_Kong,但沒Beijing。在國外獲取中國北京時間,要用”PRC”,當然”Asia/Chongqing”也是個方法:

loc, _:= time.LoadLocation("Asia/Chongqing")  //參數(shù)就是解壓文件的“目錄”+“/”+“文件名”。
fmt.Println(time.Now().In(loc))

值得強調(diào)的是,Location僅用于時區(qū)轉(zhuǎn)化,而不對time內(nèi)部的數(shù)據(jù)產(chǎn)生影響(內(nèi)部其實是unix標準時),因此,當幾個time實例進行Add、Sub的時候,不用關(guān)注Location是否相同。

時間格式化

前面例子中,打印結(jié)果非常丑陋,通常沒人關(guān)心秒之后的ns;明確時區(qū)后,很少需要與UTC的時差。這時候,就需要定義我們的layout了。

網(wǎng)上好多都說,“2006-01-02 15:04:05是go的誕生時間,所以這么設(shè)計Format的Layout”,應(yīng)該不是真的。請看下表:

01/Jan 02 03/15 04 05 06 -07[00][:00] PM Mon
時差 上下午 星期幾

也就是1234567,分別對應(yīng):月日時分秒年 時差,很好記憶。只是稍微注意一下:

  • 月:01或Jan都可以
  • 小時:03表示12小時制,15表示24小時制。
  • 時差:是 -07 ,不是 07,后邊可以增加“00”或“:00”,表示更進一步的分秒時差。
  • 上下午:使用PM,不是AM。
  • 擺放順序:隨意,甚至重復(fù)都可以。源代碼包也有定義的常用格式供使用。

也許是因為06對應(yīng)的“年”與go的項目啟動時間差不多,也就有了網(wǎng)上的誤傳。在源代碼time/time.go中,有非常明確的描述,粘貼一下,就不翻譯了:

// These are predefined layouts for use in Time.Format and Time.Parse.
// 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

雖然go已經(jīng)提供了10多個常用格式:

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"
)

但個人習慣還是“2006-01-02 15:04:05 Mon”,之前代碼稍加修改,就是這樣:

  formate:="2006-01-02 15:04:05 Mon"
  now := time.Now()
  local1, err1 := time.LoadLocation("UTC") //輸入?yún)?shù)"UTC",等同于""
  if err1 != nil {
    fmt.Println(err1)
  }
  local2, err2 := time.LoadLocation("Local")
  if err2 != nil {
    fmt.Println(err2)
  }
  local3, err3 := time.LoadLocation("America/Los_Angeles")
  if err3 != nil {
    fmt.Println(err3)
  }

  fmt.Println(now.In(local1).Format(formate))
  fmt.Println(now.In(local2).Format(formate))
  fmt.Println(now.In(local3).Format(formate))
  //output:
  //2016-12-04 08:06:39 Sun
  //2016-12-04 16:06:39 Sun
  //2016-12-04 00:06:39 Sun

時間初始化

除了最常用的time.Now,go還提供了通過unix標準時間、字符串兩種方式來初始化:

//通過字符串,默認UTC時區(qū)初始化Time
func Parse(layout, value string) (Time, error) 
//通過字符串,指定時區(qū)來初始化Time
func ParseInLocation(layout, value string, loc *Location) (Time, error) 

//通過unix 標準時間初始化Time
func Unix(sec int64, nsec int64) Time 

時間初始化的時候,一定要注意原始輸入值的時區(qū)。正好手里有一個變量,洛杉磯當?shù)貢r間“2016-11-28 19:36:25”,unix時間精確到秒為1480390585。將其解析出來的代碼如下:

  local, _ := time.LoadLocation("America/Los_Angeles")
  timeFormat := "2006-01-02 15:04:05"
  //func Unix(sec int64, nsec int64) Time {
  time1 := time.Unix(1480390585, 0)                           //通過unix標準時間的秒,納秒設(shè)置時間
  time2, _ := time.ParseInLocation(timeFormat, "2016-11-28 19:36:25", local) //洛杉磯時間
  fmt.Println(time1.In(local).Format(timeFormat))
  fmt.Println(time2.In(local).Format(timeFormat))
  chinaLocal, _ := time.LoadLocation("Local")//運行時,該服務(wù)器必須設(shè)置為中國時區(qū),否則最好是采用"Asia/Chongqing"之類具體的參數(shù)。
  fmt.Println(time2.In(chinaLocal).Format(timeFormat))
  //output:
  //2016-11-28 19:36:25
  //2016-11-28 19:36:25
  //2016-11-29 11:36:25

當然,如果輸入值是字符串,且?guī)в袝r區(qū)

“2016-12-04 15:39:06 +0800 CST”

則不需要采用ParseInLocation方法,直接使用Parse即可。

當然,其他time包中的函數(shù)還有很多,但網(wǎng)上已經(jīng)有很多描述,就不再啰嗦。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • golang的時區(qū)和神奇的time.Parse的使用方法
  • 基于golang時間轉(zhuǎn)換的問題
  • 解決Golang time.Parse和time.Format的時區(qū)問題

標簽:許昌 吐魯番 保定 東營 曲靖 貴州 德宏 常州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《golang時間、時區(qū)、格式的使用方法》,本文關(guān)鍵詞  golang,時間,時區(qū),格式,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang時間、時區(qū)、格式的使用方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于golang時間、時區(qū)、格式的使用方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章