佳木斯湛栽影视文化发展公司

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

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

熱門標簽:Linux服務器 地方門戶網站 AI電銷 百度競價排名 網站排名優(yōu)化 鐵路電話系統(tǒng) 服務外包 呼叫中心市場需求

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

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

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

對應到go,也就是幾個基本定義:

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

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

時區(qū)

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

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

  now := time.Now()
  local1, err1 := time.LoadLocation("") //等同于"UTC"
  if err1 != nil {
    fmt.Println(err1)
  }
  local2, err2 := time.LoadLocation("Local")//服務器設置的時區(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的輸入參數(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))

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

時間格式化

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

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

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

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

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

也許是因為06對應的“年”與go的項目啟動時間差不多,也就有了網上的誤傳。在源代碼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已經提供了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") //輸入參數(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標準時間的秒,納秒設置時間
  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")//運行時,該服務器必須設置為中國時區(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ù)還有很多,但網上已經有很多描述,就不再啰嗦。

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

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

標簽:崇左 黃山 銅川 仙桃 蘭州 湘潭 衡水 湖南

巨人網絡通訊聲明:本文標題《golang時間、時區(qū)、格式的使用方法》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    西乌| 晋江市| 平舆县| 河东区| 英吉沙县| 杭锦后旗| 易门县| 将乐县| 章丘市| 衡东县| 盐亭县| 焦作市| 凉城县| 麻江县| 郸城县| 宜都市| 绥阳县| 苏尼特右旗| 通州市| 杭锦后旗| 柳林县| 新疆| 宜州市| 泰州市| 田东县| 克东县| 东丰县| 南华县| 阿合奇县| 扎鲁特旗| 兴宁市| 泸水县| 林口县| 方正县| 鞍山市| 平顺县| 香河县| 安阳县| 宣汉县| 康平县| 安图县|