主頁 > 知識庫 > Go各時間字符串使用解析

Go各時間字符串使用解析

熱門標簽:宿遷便宜外呼系統(tǒng)代理商 仙桃400電話辦理 不封卡外呼系統(tǒng) 湛江crm外呼系統(tǒng)排名 重慶慶云企業(yè)400電話到哪申請 地圖標注免費定制店 上海極信防封電銷卡價格 寧波語音外呼系統(tǒng)公司 鄭州智能語音電銷機器人價格

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 方法

需要兩個參數(shù),第一個是布局,第二個是字符串

//Parse解析格式化的字符串并返回它表示的時間值。
//布局通過顯示參考時間(定義為2006年1月2日星期一1:04:05 -0700
//如果它是值,則將被解釋;它作為一個例子
//輸入格式。然后將對輸入字符串。預定義的布局ANSIC,UnixDate,RFC3339等描述了參考時間的標準和便捷表示形式。有關格式和參考時間的定義的更多信息,請參見ANSIC文檔以及此程序包定義的其他常量。
//解析時間偏移為-0700的時間時,如果偏移量對應于當前位置(本地)使用的時區(qū),則Parse在返回的時間中使用該位置和時區(qū)。否則,它將時間記錄為處于偽造位置,時間固定在給定的區(qū)域偏移量。
//
//另外,Time.Format的可執(zhí)行示例詳細說明了布局字符串的工作原理,是一個很好的參考。
//
//值中省略的元素假定為零,或者
//零不可能為1,因此解析“ 3:04 pm”將返回時間
//對應于1月1日,0,15:04:00 UTC(請注意,因為年份是
//0,此時間早于零時間)。
//年份必須在0000..9999的范圍內(nèi)。將檢查星期幾的語法,否則將忽略該語法。
//
//解析帶有MST等區(qū)域縮寫的時間時,如果該區(qū)域縮寫在當前位置具有已定義的偏移量,則使用該偏移量。
//區(qū)域縮寫“ UTC”被識別為UTC,與位置無關。
//如果未知區(qū)域縮寫,則Parse將時間記錄為位于指定位置的偽造位置,并具有零偏移量。
//此選擇意味著可以使用相同的布局無損地解析和重新格式化這樣的時間,但是表示中使用的確切瞬間將因?qū)嶋H區(qū)域偏移而有所不同。為避免此類問題,請首選使用數(shù)字區(qū)域偏移量的時間布局或使用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")
//輸出結(jié)果為time.Time格式 使用 format格式化后為 2019-08-29 16:48:21 
ParseInLocation
//ParseInLocation類似于Parse,但在兩個重要方面有所不同。
//首先,在沒有時區(qū)信息的情況下,Parse將時間解釋為UTC;
//ParseInLocation將時間解釋為給定位置。
//第二,當給定區(qū)域偏移量或縮寫時,Parse嘗試將其與本地位置進行匹配; ParseInLocation使用給定的位置
func ParseInLocation(layout, value string, loc *Location) (Time, error) {
 return parse(layout, value, loc, loc)
}

參數(shù): 1. 布局 2. 字符串 3. 時區(qū)

獲取本地時區(qū)可以使用 time.Local

使用例子:

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

解析為int64

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

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

參考文章: golang的時區(qū)和神奇的time.Parse

到此這篇關于Go各時間字符串使用解析的文章就介紹到這了,更多相關Go 時間字符串 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • golang時間字符串和時間戳轉(zhuǎn)換的案例

標簽:物業(yè)服務 儋州 西雙版納 遼寧 青海 電子產(chǎn)品 安康 海南

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