Go各時間字符串使用解析

Go 中時間格式化的模板

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

上面這些是官方定義的layout常量,我們自己也可以定義,如:

“2006-01-02 15:04:05”
“2006-01-02”
“2006-01-02 15:04”
“2006-01-02T15:04” //js和html中多用這種形式
“2006-01-02 15:03:04 -0700 MST”

Format 格式化為字符串

format 的使用對象是一個 time.Time 對象,可以使用官方或者自己定義的佈局進行格式化的輸出,如:

now := time.Now()
now.Format("2006-01-02 15:04:05") //輸出 2020-07-21 10:12:13

Parse 字符串解析為時間戳或int64

Parse 方法

需要兩個參數,第一個是佈局,第二個是字符串

//Parse解析格式化的字符串並返回它表示的時間值。
//佈局通過顯示參考時間(定義為2006年1月2日星期一1:04:05 -0700
//如果它是值,則將被解釋;它作為一個例子
//輸入格式。然後將對輸入字符串。預定義的佈局ANSIC,UnixDate,RFC3339等描述瞭參考時間的標準和便捷表示形式。有關格式和參考時間的定義的更多信息,請參見ANSIC文檔以及此程序包定義的其他常量。
//解析時間偏移為-0700的時間時,如果偏移量對應於當前位置(本地)使用的時區,則Parse在返回的時間中使用該位置和時區。否則,它將時間記錄為處於偽造位置,時間固定在給定的區域偏移量。
//
//另外,Time.Format的可執行示例詳細說明瞭佈局字符串的工作原理,是一個很好的參考。
//
//值中省略的元素假定為零,或者
//零不可能為1,因此解析“ 3:04 pm”將返回時間
//對應於1月1日,0,15:04:00 UTC(請註意,因為年份是
//0,此時間早於零時間)。
//年份必須在0000..9999的范圍內。將檢查星期幾的語法,否則將忽略該語法。
//
//解析帶有MST等區域縮寫的時間時,如果該區域縮寫在當前位置具有已定義的偏移量,則使用該偏移量。
//區域縮寫“ UTC”被識別為UTC,與位置無關。
//如果未知區域縮寫,則Parse將時間記錄為位於指定位置的偽造位置,並具有零偏移量。
//此選擇意味著可以使用相同的佈局無損地解析和重新格式化這樣的時間,但是表示中使用的確切瞬間將因實際區域偏移而有所不同。為避免此類問題,請首選使用數字區域偏移量的時間佈局或使用ParseInLocation。
func Parse(layout, value string) (Time, error) {
 return parse(layout, value, UTC, Local)
}

使用例子:

eg, err := time.Parse("2006-01-02 15:04:05 -0700 MST", "2019-08-29 16:48:21 +0800 CST")
//輸出結果為time.Time格式 使用 format格式化後為 2019-08-29 16:48:21 
ParseInLocation
//ParseInLocation類似於Parse,但在兩個重要方面有所不同。
//首先,在沒有時區信息的情況下,Parse將時間解釋為UTC;
//ParseInLocation將時間解釋為給定位置。
//第二,當給定區域偏移量或縮寫時,Parse嘗試將其與本地位置進行匹配; ParseInLocation使用給定的位置
func ParseInLocation(layout, value string, loc *Location) (Time, error) {
 return parse(layout, value, loc, loc)
}

參數: 1. 佈局 2. 字符串 3. 時區

獲取本地時區可以使用 time.Local

使用例子:

onlineAt, err := time.ParseInLocation("2006-01-02T15:04", "2020-01-02T15:04"), time.Local)

解析為int64

對於 time.Time 對象,可以使用.Unix() 方法轉為 int64,如:

eg.Unix() //默認使用 UTC時區 
eg.Local().Unix() //返回本地時區的時間戳 int64

參考文章: golang的時區和神奇的time.Parse

到此這篇關於Go各時間字符串使用解析的文章就介紹到這瞭,更多相關Go 時間字符串 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!