婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang的時區和神奇的time.Parse的使用方法

golang的時區和神奇的time.Parse的使用方法

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

時區

先寫一段測試代碼:

const TIME_LAYOUT = "2006-01-02 15:04:05"

func parseWithLocation(name string, timeStr string) (time.Time, error) {
 locationName := name
 if l, err := time.LoadLocation(locationName); err != nil {
  println(err.Error())
  return time.Time{}, err
 } else {
  lt, _ := time.ParseInLocation(TIME_LAYOUT, timeStr, l)
  fmt.Println(locationName, lt)
  return lt, nil
 }
}
func testTime() {
 fmt.Println("0. now: ", time.Now())
 str := "2018-09-10 00:00:00"
 fmt.Println("1. str: ", str)
 t, _ := time.Parse(TIME_LAYOUT, str)
 fmt.Println("2. Parse time: ", t)
 tStr := t.Format(TIME_LAYOUT)
 fmt.Println("3. Format time str: ", tStr)
 name, offset := t.Zone()
 name2, offset2 := t.Local().Zone()
 fmt.Printf("4. Zone name: %v, Zone offset: %v\n", name, offset)
 fmt.Printf("5. Local Zone name: %v, Local Zone offset: %v\n", name2, offset2)
 tLocal := t.Local()
 tUTC := t.UTC()
 fmt.Printf("6. t: %v, Local: %v, UTC: %v\n", t, tLocal, tUTC)
 fmt.Printf("7. t: %v, Local: %v, UTC: %v\n", t.Format(TIME_LAYOUT), tLocal.Format(TIME_LAYOUT), tUTC.Format(TIME_LAYOUT))
 fmt.Printf("8. Local.Unix: %v, UTC.Unix: %v\n", tLocal.Unix(), tUTC.Unix())
 str2 := "1969-12-31 23:59:59"
 t2, _ := time.Parse(TIME_LAYOUT, str2)
 fmt.Printf("9. str2:%v,time: %v, Unix: %v\n", str2, t2, t2.Unix())
 fmt.Printf("10. %v, %v\n", tLocal.Format(time.ANSIC), tUTC.Format(time.ANSIC))
 fmt.Printf("11. %v, %v\n", tLocal.Format(time.RFC822), tUTC.Format(time.RFC822))
 fmt.Printf("12. %v, %v\n", tLocal.Format(time.RFC822Z), tUTC.Format(time.RFC822Z))

 //指定時區
 parseWithLocation("America/Cordoba", str)
 parseWithLocation("Asia/Shanghai", str)
 parseWithLocation("Asia/Beijing", str)
}
testTime()

輸出:

0. now:  2018-09-19 19:06:07.3642781 +0800 CST m=+0.005995601
1. str:  2018-09-10 00:00:00
2. Parse time:  2018-09-10 00:00:00 +0000 UTC
3. Format time str:  2018-09-10 00:00:00
4. Zone name: UTC, Zone offset: 0
5. Local Zone name: CST, Local Zone offset: 28800
6. t: 2018-09-10 00:00:00 +0000 UTC, Local: 2018-09-10 08:00:00 +0800 CST, UTC: 2018-09-10 00:00:00 +0000 UTC
7. t: 2018-09-10 00:00:00, Local: 2018-09-10 08:00:00, UTC: 2018-09-10 00:00:00
8. Local.Unix: 1536537600, UTC.Unix: 1536537600
9. str2:1969-12-31 23:59:59,time: 1969-12-31 23:59:59 +0000 UTC, Unix: -1
10. Mon Sep 10 08:00:00 2018, Mon Sep 10 00:00:00 2018
11. 10 Sep 18 08:00 CST, 10 Sep 18 00:00 UTC
12. 10 Sep 18 08:00 +0800, 10 Sep 18 00:00 +0000
America/Cordoba 2018-09-10 00:00:00 -0300 -03
Asia/Shanghai 2018-09-10 00:00:00 +0800 CST
cannot find Asia/Beijing in zip file C:\Go\/lib/time/zoneinfo.zip

從以上代碼的測試結果可以得出幾點:

  • time.Now 得到的當前時間的時區跟電腦的當前時區一樣。
  • time.Parse 把時間字符串轉換為Time,時區是UTC時區。
  • 不管Time變量存儲的是什么時區,其Unix()方法返回的都是距離UTC時間:1970年1月1日0點0分0秒的秒數。
  • Unix()返回的秒數可以是負數,如果時間小于1970-01-01 00:00:00的話。
  • Zone方法可以獲得變量的時區和時區與UTC的偏移秒數,應該支持夏令時和冬令時。
  • time.LoadLocation可以根據時區名創建時區Location,所有的時區名字可以在$GOROOT/lib/time/zoneinfo.zip文件中找到,解壓zoneinfo.zip可以得到一堆目錄和文件,我們只需要目錄和文件的名字,時區名是目錄名+文件名,比如"Asia/Shanghai"。中國時區名只有"Asia/Shanghai"和"Asia/Chongqing",而沒有"Asia/Beijing"。
  • time.ParseInLocation可以根據時間字符串和指定時區轉換Time。
  • 感謝中國只有一個時區而且沒有夏令時和冬令時,可怕的美國居然有6個時區,想想都可怕。

神奇的time.Parse

一開始使用time.Parse時很不習慣,因為非常奇怪的layout參數。
除了golang自帶定義的layout:

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"

網上基本上都在傳說這個日子是golang項目開始創建的時間,為了紀念生日才這樣設計,其實這真是無稽之談瞎扯淡。
網上文章沒有找到說的比較清楚的,幸好有源碼,打開time.Parse的源碼看了一下,發現這個設計很好很科學。
解析layout的主要代碼在nextStdChunk方法中:

// nextStdChunk finds the first occurrence of a std string in
// layout and returns the text before, the std string, and the text after.
func nextStdChunk(layout string) (prefix string, std int, suffix string) {
 for i := 0; i  len(layout); i++ {
  switch c := int(layout[i]); c {
  case 'J': // January, Jan
   if len(layout) >= i+3  layout[i:i+3] == "Jan" {
    if len(layout) >= i+7  layout[i:i+7] == "January" {
     return layout[0:i], stdLongMonth, layout[i+7:]
    }
    if !startsWithLowerCase(layout[i+3:]) {
     return layout[0:i], stdMonth, layout[i+3:]
    }
   }

  case 'M': // Monday, Mon, MST
   if len(layout) >= i+3 {
    if layout[i:i+3] == "Mon" {
     if len(layout) >= i+6  layout[i:i+6] == "Monday" {
      return layout[0:i], stdLongWeekDay, layout[i+6:]
     }
     if !startsWithLowerCase(layout[i+3:]) {
      return layout[0:i], stdWeekDay, layout[i+3:]
     }
    }
    if layout[i:i+3] == "MST" {
     return layout[0:i], stdTZ, layout[i+3:]
    }
   }

  case '0': // 01, 02, 03, 04, 05, 06
   if len(layout) >= i+2  '1' = layout[i+1]  layout[i+1] = '6' {
    return layout[0:i], std0x[layout[i+1]-'1'], layout[i+2:]
   }

  case '1': // 15, 1
   if len(layout) >= i+2  layout[i+1] == '5' {
    return layout[0:i], stdHour, layout[i+2:]
   }
   return layout[0:i], stdNumMonth, layout[i+1:]

  case '2': // 2006, 2
   if len(layout) >= i+4  layout[i:i+4] == "2006" {
    return layout[0:i], stdLongYear, layout[i+4:]
   }
   return layout[0:i], stdDay, layout[i+1:]

  case '_': // _2, _2006
   if len(layout) >= i+2  layout[i+1] == '2' {
    //_2006 is really a literal _, followed by stdLongYear
    if len(layout) >= i+5  layout[i+1:i+5] == "2006" {
     return layout[0 : i+1], stdLongYear, layout[i+5:]
    }
    return layout[0:i], stdUnderDay, layout[i+2:]
   }

  case '3':
   return layout[0:i], stdHour12, layout[i+1:]

  case '4':
   return layout[0:i], stdMinute, layout[i+1:]

  case '5':
   return layout[0:i], stdSecond, layout[i+1:]

  case 'P': // PM
   if len(layout) >= i+2  layout[i+1] == 'M' {
    return layout[0:i], stdPM, layout[i+2:]
   }

  case 'p': // pm
   if len(layout) >= i+2  layout[i+1] == 'm' {
    return layout[0:i], stdpm, layout[i+2:]
   }

  case '-': // -070000, -07:00:00, -0700, -07:00, -07
   if len(layout) >= i+7  layout[i:i+7] == "-070000" {
    return layout[0:i], stdNumSecondsTz, layout[i+7:]
   }
   if len(layout) >= i+9  layout[i:i+9] == "-07:00:00" {
    return layout[0:i], stdNumColonSecondsTZ, layout[i+9:]
   }
   if len(layout) >= i+5  layout[i:i+5] == "-0700" {
    return layout[0:i], stdNumTZ, layout[i+5:]
   }
   if len(layout) >= i+6  layout[i:i+6] == "-07:00" {
    return layout[0:i], stdNumColonTZ, layout[i+6:]
   }
   if len(layout) >= i+3  layout[i:i+3] == "-07" {
    return layout[0:i], stdNumShortTZ, layout[i+3:]
   }

  case 'Z': // Z070000, Z07:00:00, Z0700, Z07:00,
   if len(layout) >= i+7  layout[i:i+7] == "Z070000" {
    return layout[0:i], stdISO8601SecondsTZ, layout[i+7:]
   }
   if len(layout) >= i+9  layout[i:i+9] == "Z07:00:00" {
    return layout[0:i], stdISO8601ColonSecondsTZ, layout[i+9:]
   }
   if len(layout) >= i+5  layout[i:i+5] == "Z0700" {
    return layout[0:i], stdISO8601TZ, layout[i+5:]
   }
   if len(layout) >= i+6  layout[i:i+6] == "Z07:00" {
    return layout[0:i], stdISO8601ColonTZ, layout[i+6:]
   }
   if len(layout) >= i+3  layout[i:i+3] == "Z07" {
    return layout[0:i], stdISO8601ShortTZ, layout[i+3:]
   }

  case '.': // .000 or .999 - repeated digits for fractional seconds.
   if i+1  len(layout)  (layout[i+1] == '0' || layout[i+1] == '9') {
    ch := layout[i+1]
    j := i + 1
    for j  len(layout)  layout[j] == ch {
     j++
    }
    // String of digits must end here - only fractional second is all digits.
    if !isDigit(layout, j) {
     std := stdFracSecond0
     if layout[i+1] == '9' {
      std = stdFracSecond9
     }
     std |= (j - (i + 1))  stdArgShift
     return layout[0:i], std, layout[j:]
    }
   }
  }
 }
 return layout, 0, ""
}

可以發現layout的所有代表年月日時分秒甚至時區的值都是互斥不相等的。

比如年份:短年份06,長年份2006,
月份:01,Jan,January
日:02,2,_2
時:15,3,03
分:04, 4
秒:05, 5

因為都不相等所以通過遍歷layout就可以switch case解析出每個區塊的意義和在字符串中的位置,這樣輸入對應格式的時間字符串就可以順利解析出來。
這樣layout也可以自定義,而且順序任意,只要符合下列每個區塊定義的規則即可,
代碼中的注釋就是規則寫法:

const (
 _      = iota
 stdLongMonth    = iota + stdNeedDate // "January"
 stdMonth          // "Jan"
 stdNumMonth         // "1"
 stdZeroMonth         // "01"
 stdLongWeekDay         // "Monday"
 stdWeekDay          // "Mon"
 stdDay           // "2"
 stdUnderDay         // "_2"
 stdZeroDay          // "02"
 stdHour     = iota + stdNeedClock // "15"
 stdHour12          // "3"
 stdZeroHour12         // "03"
 stdMinute          // "4"
 stdZeroMinute         // "04"
 stdSecond          // "5"
 stdZeroSecond         // "05"
 stdLongYear    = iota + stdNeedDate // "2006"
 stdYear          // "06"
 stdPM     = iota + stdNeedClock // "PM"
 stdpm           // "pm"
 stdTZ     = iota    // "MST"
 stdISO8601TZ         // "Z0700" // prints Z for UTC
 stdISO8601SecondsTZ       // "Z070000"
 stdISO8601ShortTZ        // "Z07"
 stdISO8601ColonTZ        // "Z07:00" // prints Z for UTC
 stdISO8601ColonSecondsTZ      // "Z07:00:00"
 stdNumTZ          // "-0700" // always numeric
 stdNumSecondsTz        // "-070000"
 stdNumShortTZ         // "-07" // always numeric
 stdNumColonTZ         // "-07:00" // always numeric
 stdNumColonSecondsTZ       // "-07:00:00"
 stdFracSecond0         // ".0", ".00", ... , trailing zeros included
 stdFracSecond9         // ".9", ".99", ..., trailing zeros omitted

 stdNeedDate = 1  8    // need month, day, year
 stdNeedClock = 2  8    // need hour, minute, second
 stdArgShift = 16     // extra argument in high bits, above low stdArgShift
 stdMask  = 1stdArgShift - 1 // mask out argument
)

時區:

時區使用:MST
時區偏移使用-0700或者Z0700等等。
下面是一個使用時區的例子,Z0700比較特殊,當輸入時間直接使用Z時就直接代表UTC時區。

func testTimeParse() {
 t, _ := time.Parse("2006-01-02 15:04:05 -0700 MST", "2018-09-20 15:39:06 +0800 CST")
 fmt.Println(t)
 t, _ = time.Parse("2006-01-02 15:04:05 -0700 MST", "2018-09-20 15:39:06 +0000 CST")
 fmt.Println(t)
 t, _ = time.Parse("2006-01-02 15:04:05 Z0700 MST", "2018-09-20 15:39:06 +0800 CST")
 fmt.Println(t)
 t, _ = time.Parse("2006-01-02 15:04:05 Z0700 MST", "2018-09-20 15:39:06 Z GMT")
 fmt.Println(t)
 t, _ = time.Parse("2006-01-02 15:04:05 Z0700 MST", "2018-09-20 15:39:06 +0000 GMT")
 fmt.Println(t)
}

輸出:
2018-09-20 15:39:06 +0800 CST
2018-09-20 15:39:06 +0000 CST
2018-09-20 15:39:06 +0800 CST
2018-09-20 15:39:06 +0000 UTC
2018-09-20 15:39:06 +0000 GMT

還有疑問的可以看看go自帶的測試例子:Go/src/time/example_test.go

到此這篇關于golang的時區和神奇的time.Parse的使用方法的文章就介紹到這了,更多相關golang的時區和time.Parse內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • golang 定時任務方面time.Sleep和time.Tick的優劣對比分析
  • 解決Golang time.Parse和time.Format的時區問題
  • 解決golang時間字符串轉time.Time的坑
  • 對Golang中的runtime.Caller使用說明
  • Golang中的time.Duration類型用法說明
  • golang time包做時間轉換操作
  • golang xorm及time.Time自定義解決json日期格式的問題
  • golang time常用方法詳解

標簽:物業服務 儋州 海南 西雙版納 青海 遼寧 電子產品 安康

巨人網絡通訊聲明:本文標題《golang的時區和神奇的time.Parse的使用方法》,本文關鍵詞  golang,的,時區,和,神奇,time.Parse,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang的時區和神奇的time.Parse的使用方法》相關的同類信息!
  • 本頁收集關于golang的時區和神奇的time.Parse的使用方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人白浆超碰人人人人| 日本欧美肥老太交大片| 国产高清一区日本| 亚洲国产精品成人综合| 欧美一级精品大片| 日韩欧美一区二区视频| 日韩一区二区免费电影| 久久午夜电影网| 精品国产亚洲在线| 久久尤物电影视频在线观看| 国产午夜精品在线观看| 中文字幕 久热精品 视频在线| 亚洲丰满少妇videoshd| 91国产丝袜在线播放| 日本成人在线一区| 国产女主播一区| 色妞www精品视频| 日本中文字幕一区二区有限公司| 日韩精品一区在线| 成人av在线资源| 午夜精品在线视频一区| 久久久久久久久免费| 91美女在线视频| 免费在线视频一区| 国产精品久久毛片av大全日韩| 欧美日韩一区二区三区在线| 国产在线一区二区综合免费视频| 亚洲日本在线天堂| 欧美精品在线观看一区二区| 国产不卡视频在线播放| 亚洲成a人片综合在线| 久久久久久久免费视频了| 在线观看不卡一区| 国产成人综合在线| 亚洲成人在线观看视频| 国产欧美精品区一区二区三区| 日本高清无吗v一区| 国产一区二区三区黄视频 | 免费观看久久久4p| 国产欧美日韩视频在线观看| 欧美日韩一区不卡| 国产盗摄精品一区二区三区在线| 亚洲愉拍自拍另类高清精品| 久久精品网站免费观看| 777久久久精品| 99视频超级精品| 国产麻豆精品视频| 午夜欧美一区二区三区在线播放| 国产精品入口麻豆九色| 亚洲精品一区二区三区蜜桃下载 | 色综合色狠狠天天综合色| 九色综合狠狠综合久久| 亚洲成人三级小说| 亚洲欧美另类综合偷拍| 国产精品18久久久久久久久久久久 | 成人污污视频在线观看| 欧美精三区欧美精三区| 中文字幕在线不卡| 久久伊人蜜桃av一区二区| 在线不卡a资源高清| 欧美在线观看一区| 99精品国产视频| 成人性生交大片免费看在线播放| 国产自产2019最新不卡| 看电视剧不卡顿的网站| 免费人成在线不卡| 日韩国产精品久久久久久亚洲| 亚洲在线观看免费| 亚洲黄色片在线观看| 亚洲色图在线播放| 亚洲欧美国产毛片在线| 亚洲欧美日韩国产综合在线| 日韩一区有码在线| 国产精品每日更新| 国产精品国产三级国产三级人妇 | 欧美一区二区啪啪| 欧美人体做爰大胆视频| 欧美人牲a欧美精品| 91麻豆精品国产自产在线 | 亚洲高清免费视频| 一区二区三区国产精华| 一区二区三区影院| 亚洲影院免费观看| 舔着乳尖日韩一区| 首页国产欧美久久| 日韩激情在线观看| 免费成人在线影院| 国模套图日韩精品一区二区| 久久精品国产久精国产爱| 韩日欧美一区二区三区| 国产精品自产自拍| 成人av高清在线| 91视视频在线观看入口直接观看www| 99精品久久99久久久久| 欧美日韩一二三| 日韩视频一区在线观看| 国产欧美日韩不卡| 日韩美女视频一区| 午夜精品久久久久久久久| 老司机精品视频在线| 成人一级视频在线观看| 91成人网在线| 日韩欧美中文一区二区| 国产欧美日韩在线视频| 色婷婷av一区二区三区软件| 欧美精品自拍偷拍| 亚洲午夜免费电影| 欧美日本一道本在线视频| 激情综合五月婷婷| 亚洲欧美一区二区在线观看| 91精品国产品国语在线不卡| 国产精品91一区二区| 欧美成人综合网站| 久久婷婷国产综合国色天香| 亚洲免费av观看| 老司机免费视频一区二区 | 色婷婷综合久久久久中文| 欧美久久久久久久久中文字幕| 久久亚洲一区二区三区四区| 亚洲美女视频在线| 久久精品国产澳门| 色综合久久久久综合99| 日韩午夜激情免费电影| 亚洲日本在线a| 激情综合网激情| 欧美日韩aaaaa| 中文字幕一区二区三区四区| 日精品一区二区| 91一区二区三区在线观看| 日韩午夜电影av| 亚洲综合激情网| 高清不卡一区二区在线| 日韩一区二区精品| 亚洲另类色综合网站| 国产一区二区三区观看| 91精品国产一区二区三区 | 正在播放一区二区| 亚洲精品免费在线| 国产电影一区在线| 欧美一级艳片视频免费观看| 亚洲黄色尤物视频| 成人激情视频网站| 久久综合色播五月| 日本伊人午夜精品| 一本大道久久a久久精二百 | 91丝袜高跟美女视频| 久久免费视频一区| 美女看a上一区| 欧美精品乱码久久久久久| 日韩美女视频一区二区| 国产成人啪午夜精品网站男同| 日韩精品最新网址| 天堂在线亚洲视频| 在线观看国产精品网站| 亚洲精品免费电影| av成人免费在线| 国产精品欧美久久久久无广告| 国产在线精品国自产拍免费| 精品国产乱子伦一区| 美女网站一区二区| 日韩免费视频线观看| 奇米精品一区二区三区四区| 欧美精品久久久久久久久老牛影院| 在线观看亚洲专区| 亚洲欧美经典视频| 日本乱码高清不卡字幕| 国产一区二区精品久久| 国产一区中文字幕| 丰满岳乱妇一区二区三区| 91在线观看污| 欧美三片在线视频观看| 精品国产不卡一区二区三区| 国产网站一区二区| 奇米影视7777精品一区二区| 精品少妇一区二区三区视频免付费 | 久久久久亚洲综合| 高清国产一区二区三区| 综合精品久久久| 在线精品观看国产| 午夜欧美电影在线观看| 日韩午夜激情电影| 国产精品一区二区无线| 国产精品色眯眯| 欧美午夜免费电影| 日韩精品91亚洲二区在线观看| 精品日韩在线观看| 99久久久国产精品免费蜜臀| 亚洲一区中文日韩| 26uuu亚洲婷婷狠狠天堂| 岛国一区二区在线观看| 一区二区三区精品在线| 91精品午夜视频| 国产suv精品一区二区6| 亚洲成va人在线观看| 久久久国产精品不卡| 日本高清无吗v一区| 久久99国产精品久久99果冻传媒| 国产精品国产三级国产普通话蜜臀 | 国产欧美日本一区视频| 色狠狠综合天天综合综合|