go語言中的Carbon庫時間處理技巧
go語言之Carbon庫
- carbon是一個時間擴展庫,它提供了易于使用接口。
- 簡單示例:
package main import ( "fmt" "github.com/uniplaces/carbon" "time" ) func main() { // 打印當(dāng)前時間 now :=carbon.Now().DateTimeString() fmt.Println("本地時間:", now) Japantoday, _ := carbon.NowInLocation("Japan") fmt.Println("日本時間:", Japantoday) // 明天 tomorrow := carbon.Now().AddDay() fmt.Println(tomorrow) // 上周的今天 subweek := carbon.Now().SubWeek() fmt.Println(subweek) nextOlympics, _ := carbon.CreateFromDate(2016, time.August,5,"Europe/London") fmt.Println("2016年奧林匹克運動會:",nextOlympics) nextOlympics = nextOlympics.AddYears(4) fmt.Println("下一次奧林匹克運動會:", nextOlympics.Year()) if carbon.Now().IsWeekend() { fmt.Println("休息的一天") } else { fmt.Println("工作日") } }
carbon庫非常便捷,它完全兼容time.Time類型,實際上它日期時間類型Carbon直接將time.Time內(nèi)嵌到結(jié)構(gòu)中,所以time.Time方法可直接調(diào)用。
// The Carbon type represents a Time instance. // Provides a simple API extension for Time. type Carbon struct { time.Time weekStartsAt time.Weekday weekEndsAt time.Weekday weekendDays []time.Weekday stringFormat string Translator *Translator }
其次,簡化了創(chuàng)建操作。標(biāo)準(zhǔn)庫time
創(chuàng)建一個Time
對象,如果不是本地或 UTC 時區(qū),需要自己先調(diào)用LoadLocation
加載對應(yīng)時區(qū)。然后將該時區(qū)對象傳給time.Date
方法創(chuàng)建。carbon
可以直接傳時區(qū)名字。
1.時區(qū)
使用go語言time,創(chuàng)建時區(qū)需要先加載時區(qū)。
loc, err := time.LoadLocation("Japan") if err != nil { log.Fatal("failed to load location:", err) } d := time.Date(2020, time.July,24,20,0,0,0,loc) fmt.Println(d) // 2020-07-24 20:00:00 +0900 JST
使用carbon就簡單很多
loc, err := carbon.Create(2020,time.July,24,20,0,0,0,"Japan") if err != nil { log.Fatal(err) } fmt.Println(loc)// 2020-07-24 20:00:00
2.時間運算
now := carbon.Now() fmt.Println(now) fmt.Println("1秒后:", now.AddSecond()) fmt.Println("1分鐘后:", now.AddMinute()) fmt.Println("1小時后:", now.AddHour()) fmt.Println("3分鐘20秒后:", now.AddMinutes(3).AddSeconds(20)) fmt.Println("2小時30分后:", now.AddHours(2).AddMinutes(30)) fmt.Println("3天2小時后:",now.AddDays(3).AddHours(2))
- 增加季度的方法:
AddQuarters/AddQuarter
,復(fù)數(shù)形式介紹一個表示倍數(shù)的參數(shù),單數(shù)形式倍數(shù)為1; - 增加世紀(jì)的方法:
AddCenturies/AddCentury
; - 增加工作日的方法:
AddWeekdays/AddWeekday
,這個方法會跳過非工作日; - 增加周的方法:
AddWeeks/AddWeek
。
其實給上面方法傳入負(fù)數(shù)就表示減少,另外carbon
也提供了對應(yīng)的Sub*
方法。
3.時間比較
carbon計算兩個日期之間相差多少秒,份,小時,天:
vancouver, _ := carbon.Today("Asia/Shanghai") london, _ := carbon.Today("Asia/Hong_Kong") // 相差秒數(shù) fmt.Println(vancouver.DiffInSeconds(london, true)) // 0 ottawa, _ := carbon.CreateFromDate(2000, 1, 1, "America/Toronto") vancouver, _ = carbon.CreateFromDate(2000, 1, 1, "America/Vancouver") fmt.Println(ottawa.DiffInHours(vancouver, true)) // 3 fmt.Println(ottawa.DiffInHours(vancouver, false)) // 3 fmt.Println(vancouver.DiffInHours(ottawa, false)) // -3 t, _ := carbon.CreateFromDate(2012, 1, 31, "UTC") fmt.Println(t.DiffInDays(t.AddMonth(), true)) // 31 fmt.Println(t.DiffInDays(t.SubMonth(), false)) // -31 t, _ = carbon.CreateFromDate(2012, 4, 30, "UTC") fmt.Println(t.DiffInDays(t.AddMonth(), true)) // 30 fmt.Println(t.DiffInDays(t.AddWeek(), true)) // 7 t, _ = carbon.CreateFromTime(10, 1, 1, 0, "UTC") fmt.Println(t.DiffInMinutes(t.AddSeconds(59), true)) // 0 fmt.Println(t.DiffInMinutes(t.AddSeconds(60), true)) // 1 fmt.Println(t.DiffInMinutes(t.AddSeconds(119), true)) // 1 fmt.Println(t.DiffInMinutes(t.AddSeconds(120), true)) // 2
4.格式化
我們知道time.Time
提供了一個Format
方法,相比于其他編程語言使用格式化符來描述格式(需要記憶%d/%m/%h
等的含義),Go 提供了一個一種更簡單、直觀的方式——使用 layout。即我們傳入一個日期字符串,表示我們想要格式化成什么樣子。Go 會用當(dāng)前的時間替換字符串中的對應(yīng)部分:
package main import ( "fmt" "time" ) func main() { t := time.Now() fmt.Println(t.Format("2006-01-02 10:00:00")) }
上面我們只需要傳入一個2006-01-02 10:00:00
表示我們想要的格式為yyyy-mm-dd hh:mm:ss
,省去了我們需要記憶的麻煩
為了使用方便,Go 內(nèi)置了一些標(biāo)準(zhǔn)的時間格式:
/ src/time/format.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"http:// 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"http:// 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" )
除了上面這些格式,carbon
還提供了其他一些格式:
const ( DefaultFormat = "2006-01-02 15:04:05" DateFormat = "2006-01-02" FormattedDateFormat = "Jan 2, 2006" TimeFormat = "15:04:05" HourMinuteFormat = "15:04" HourFormat = "15" DayDateTimeFormat = "Mon, Aug 2, 2006 3:04 PM" CookieFormat = "Monday, 02-Jan-2006 15:04:05 MST" RFC822Format = "Mon, 02 Jan 06 15:04:05 -0700" RFC1036Format = "Mon, 02 Jan 06 15:04:05 -0700" RFC2822Format = "Mon, 02 Jan 2006 15:04:05 -0700" RSSFormat = "Mon, 02 Jan 2006 15:04:05 -0700" )
5.高級特性
所謂修飾器(modifier)就是對一些特定的時間操作,獲取開始和結(jié)束時間。如當(dāng)天、月、季度、年、十年、世紀(jì)、周的開始和結(jié)束時間,還能獲得上一個周二、下一個周一、下一個工作日的時間等等:
t := carbon.Now() fmt.Println("今天起始:", t.StartOfDay()) fmt.Println("今天終止:", t.EndOfDay()) fmt.Println("本月起始:", t.StartOfMonth()) fmt.Println("本月終止:", t.EndOfMonth()) fmt.Println("本年起始:", t.StartOfYear()) fmt.Println("本年終止:", t.EndOfYear()) fmt.Println("今年起始日期(年月日時分秒):", t.StartOfDecade()) fmt.Println("今年終止日期(年月日時分秒):", t.EndOfDecade()) fmt.Println("本世紀(jì)起始日期(年月日時分秒):", t.StartOfCentury()) fmt.Println("本世紀(jì)終止日期(年月日時分秒):", t.EndOfCentury()) fmt.Println("本周起始日期(年月日時分秒):", t.StartOfWeek()) fmt.Println("本周終止日期(年月日時分秒):", t.EndOfWeek())
6.自定義工作日和周末
func main() { t, err := carbon.Create(2020, 02, 11, 0, 0, 0, 0, "Asia/Shanghai") if err != nil { log.Fatal(err) } t.SetWeekStartsAt(time.Sunday) t.SetWeekEndsAt(time.Saturday) t.SetWeekendDays([]time.Weekday{time.Monday, time.Tuesday, time.Wednesday}) fmt.Printf("今天是 %s, weekend? %t\n", t.Weekday(), t.IsWeekend()) }
到此這篇關(guān)于go語言中的Carbon庫時間處理的文章就介紹到這了,更多相關(guān)go Carbon庫時間處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
golang?sync.Cond同步機制運用及實現(xiàn)
在?Go?里有專門為同步通信而生的?channel,所以較少看到?sync.Cond?的使用,不過它也是并發(fā)控制手段里的一種,今天我們就來認(rèn)識下它的相關(guān)實現(xiàn),加深對同步機制的運用2023-09-09一文帶你了解Golang中select的實現(xiàn)原理
select是go提供的一種跟并發(fā)相關(guān)的語法,非常有用。本文將介紹?Go?語言中的?select?的實現(xiàn)原理,包括?select?的結(jié)構(gòu)和常見問題、編譯期間的多種優(yōu)化以及運行時的執(zhí)行過程2023-02-02