项目介绍

Carbon 是一个轻量级、语义化、对开发者友好的 golang 时间处理库,支持链式调用

Carbon 已被 awesome-go 收录, 如果您觉得不错,请给个 star 吧

github.com/golang-module/carbon

gitee.com/go-package/carbon

安装使用

// 使用 github 库go get -u github.com/golang-module/carbonimport ( "github.com/golang-module/carbon")// 使用 gitee 库go get -u gitee.com/go-package/carbonimport ( "gitee.com/go-package/carbon")

用法示例

默认时区为 Local,即服务器所在时区,假设当前时间为 2020-08-05 13:14:15

昨天、今天、明天
// 今天此刻fmt.Sprintf("%s", carbon.Now()) // 2020-08-05 13:14:15carbon.Now().ToDateTimeString() // 2020-08-05 13:14:15// 今天日期carbon.Now().ToDateString() // 2020-08-05// 今天时间carbon.Now().ToTimeString() // 13:14:15// 今天秒级时间戳carbon.Now().ToTimestamp() // 1596604455carbon.Now().ToTimestampWithSecond() // 1596604455// 今天毫秒级时间戳carbon.Now().ToTimestampWithMillisecond() // 1596604455000// 今天微秒级时间戳carbon.Now().ToTimestampWithMicrosecond() // 1596604455000000// 今天纳秒级时间戳carbon.Now().ToTimestampWithNanosecond() // 1596604455000000000// 指定时区的今天此刻carbon.Now(Carbon.NewYork).ToDateTimeString() // 2020-08-05 14:14:15carbon.SetTimezone(Carbon.NewYork).Now().ToDateTimeString() // 2020-08-05 14:14:15// 昨天此刻fmt.Sprintf("%s", carbon.Yesterday()) // 2020-08-04 13:14:15carbon.Yesterday().ToDateTimeString() // 2020-08-04 13:14:15// 昨天日期carbon.Yesterday().ToDateString() // 2020-08-04// 昨天时间carbon.Yesterday().ToTimeString() // 13:14:15// 昨天秒级时间戳carbon.Yesterday().ToTimestamp() // 1596518055carbon.Yesterday().ToTimestampWithSecond() // 1596518055// 昨天毫秒级时间戳carbon.Yesterday().ToTimestampWithMillisecond() // 1596518055000// 昨天微秒级时间戳carbon.Yesterday().ToTimestampWithMicrosecond() // 1596518055000000// 昨天纳秒级时间戳carbon.Yesterday().ToTimestampWithNanosecond() // 1596518055000000000// 指定日期的昨天此刻carbon.Parse("2021-01-28 13:14:15").Yesterday().ToDateTimeString() // 2021-01-27 13:14:15// 指定时区的昨天此刻carbon.Yesterday(Carbon.NewYork).ToDateTimeString() // 2020-08-04 14:14:15carbon.SetTimezone(Carbon.NewYork).Yesterday().ToDateTimeString() // 2020-08-04 14:14:15// 明天此刻fmt.Sprintf("%s", carbon.Tomorrow()) // 2020-08-06 13:14:15carbon.Tomorrow().ToDateTimeString() // 2020-08-06 13:14:15// 明天日期carbon.Tomorrow().ToDateString() // 2020-08-06// 明天时间carbon.Tomorrow().ToTimeString() // 13:14:15// 明天秒级时间戳carbon.Tomorrow().ToTimestamp() // 1596690855carbon.Tomorrow().ToTimestampWithSecond() // 1596690855// 明天毫秒级时间戳carbon.Tomorrow().ToTimestampWithMillisecond() // 1596690855000// 明天微秒级时间戳carbon.Tomorrow().ToTimestampWithMicrosecond() // 1596690855000000// 明天纳秒级时间戳carbon.Tomorrow().ToTimestampWithNanosecond() // 1596690855000000000// 指定日期的明天此刻carbon.Parse("2021-01-28 13:14:15").Tomorrow().ToDateTimeString() // 2021-01-29 13:14:15// 指定时区的明天此刻carbon.Tomorrow(Carbon.NewYork).ToDateTimeString() // 2020-08-06 14:14:15carbon.SetTimezone(Carbon.NewYork).Tomorrow().ToDateTimeString() // 2020-08-06 14:14:15
创建 Carbon 实例
// 从秒级时间戳创建 Carbon 实例carbon.CreateFromTimestamp(-1).ToDateTimeString() // 1970-01-01 07:59:59carbon.CreateFromTimestamp(-1, carbon.Tokyo).ToDateTimeString() // 1970-01-01 08:59:59carbon.CreateFromTimestamp(0).ToDateTimeString() // 1970-01-01 08:00:00carbon.CreateFromTimestamp(0, carbon.Tokyo).ToDateTimeString() // 1970-01-01 09:00:00carbon.CreateFromTimestamp(1596604455).ToDateTimeString() // 2020-08-05 13:14:15carbon.CreateFromTimestamp(1596604455, carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15// 从毫秒级时间戳创建 Carbon 实例carbon.CreateFromTimestamp(1596604455000).ToDateTimeString() // 2020-08-05 13:14:15carbon.CreateFromTimestamp(1596604455000, carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15// 从微秒级时间戳创建 Carbon 实例carbon.CreateFromTimestamp(1596604455000000).ToDateTimeString() // 2020-08-05 13:14:15carbon.CreateFromTimestamp(1596604455000000, carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15// 从纳级时间戳创建 Carbon 实例carbon.CreateFromTimestamp(1596604455000000000).ToDateTimeString() // 2020-08-05 13:14:15carbon.CreateFromTimestamp(1596604455000000000, carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15// 从年月日时分秒创建 Carbon 实例carbon.CreateFromDateTime(2020, 8, 5, 13, 14, 15).ToDateTimeString() // 2020-08-05 13:14:15carbon.CreateFromDateTime(2020, 8, 5, 13, 14, 15, carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15// 从年月日创建 Carbon 实例(时分秒默认为当前时分秒)carbon.CreateFromDate(2020, 8, 5).ToDateTimeString() // 2020-08-05 13:14:15carbon.CreateFromDate(2020, 8, 5, carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15// 从时分秒创建 Carbon 实例(年月日默认为当前年月日)carbon.CreateFromTime(13, 14, 15).ToDateTimeString() // 2020-08-05 13:14:15carbon.CreateFromTime(13, 14, 15, carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15
将标准格式时间字符串解析成 Carbon 实例
carbon.Parse("").ToDateTimeString() // 空字符串carbon.Parse("0").ToDateTimeString() // 空字符串carbon.Parse("0000-00-00 00:00:00").ToDateTimeString() // 空字符串carbon.Parse("0000-00-00").ToDateTimeString() // 空字符串carbon.Parse("00:00:00").ToDateTimeString() // 空字符串carbon.Parse("2020-08-05 13:14:15").ToDateTimeString() // 2020-08-05 13:14:15carbon.Parse("2020-08-05").ToDateTimeString() // 2020-08-05 00:00:00carbon.Parse("20200805131415").ToDateTimeString() // 2020-08-05 13:14:15carbon.Parse("20200805").ToDateTimeString() // 2020-08-05 00:00:00carbon.Parse("2020-08-05T13:14:15+08:00").ToDateTimeString() // 2020-08-05 13:14:15carbon.Parse("2020-08-05 13:14:15", carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15
通过格式化字符将字符串解析成 Carbon 实例

如果使用的字母与格式化字符冲突时,请使用转义符转义该字母

carbon.ParseByFormat("2020|08|05 13|14|15", "Y|m|d H|i|s").ToDateTimeString() // 2020-08-05 13:14:15carbon.ParseByFormat("It is 2020-08-05 13:14:15", "\\I\\t \\i\\s Y-m-d H:i:s").ToDateTimeString() // 2020-08-05 13:14:15carbon.ParseByFormat("今天是 2020年08月05日13时14分15秒", "今天是 Y年m月d日H时i分s秒").ToDateTimeString() // 2020-08-05 13:14:15carbon.ParseByFormat("2020-08-05 13:14:15", "Y-m-d H:i:s", carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15
通过布局字符将字符串解析成 Carbon 实例
carbon.ParseByLayout("2020|08|05 13|14|15", "2006|01|02 15|04|05").ToDateTimeString() // 2020-08-05 13:14:15carbon.ParseByLayout("It is 2020-08-05 13:14:15", "It is 2006-01-02 15:04:05").ToDateTimeString() // 2020-08-05 13:14:15carbon.ParseByLayout("今天是 2020年08月05日13时14分15秒", "今天是 2006年01月02日15时04分05秒").ToDateTimeString() // 2020-08-05 13:14:15carbon.ParseByLayout("2020-08-05 13:14:15", "2006-01-02 15:04:05", carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15
Carbon 和 time.Time 互转
// 将 time.Time 转换成 Carboncarbon.Time2Carbon(time.Now())// 将 Carbon 转换成 time.Timecarbon.Now().Carbon2Time()
开始时间、结束时间
// 本世纪开始时间carbon.Parse("2020-08-05 13:14:15").StartOfCentury().ToDateTimeString() // 2000-01-01 00:00:00// 本世纪结束时间carbon.Parse("2020-08-05 13:14:15").EndOfCentury().ToDateTimeString() // 2999-12-31 23:59:59// 本年代开始时间carbon.Parse("2020-08-05 13:14:15").StartOfDecade().ToDateTimeString() // 2020-01-01 00:00:00carbon.Parse("2021-08-05 13:14:15").StartOfDecade().ToDateTimeString() // 2020-01-01 00:00:00carbon.Parse("2029-08-05 13:14:15").StartOfDecade().ToDateTimeString() // 2020-01-01 00:00:00// 本年代结束时间carbon.Parse("2020-08-05 13:14:15").EndOfDecade().ToDateTimeString() // 2029-12-31 23:59:59carbon.Parse("2021-08-05 13:14:15").EndOfDecade().ToDateTimeString() // 2029-12-31 23:59:59carbon.Parse("2029-08-05 13:14:15").EndOfDecade().ToDateTimeString() // 2029-12-31 23:59:59// 本年开始时间carbon.Parse("2020-08-05 13:14:15").StartOfYear().ToDateTimeString() // 2020-01-01 00:00:00// 本年结束时间carbon.Parse("2020-08-05 13:14:15").EndOfYear().ToDateTimeString() // 2020-12-31 23:59:59// 本季度开始时间carbon.Parse("2020-08-05 13:14:15").StartOfQuarter().ToDateTimeString() // 2020-07-01 00:00:00// 本季度结束时间carbon.Parse("2020-08-05 13:14:15").EndOfQuarter().ToDateTimeString() // 2020-09-30 23:59:59// 本月开始时间carbon.Parse("2020-08-05 13:14:15").StartOfMonth().ToDateTimeString() // 2020-08-01 00:00:00// 本月结束时间carbon.Parse("2020-08-05 13:14:15").EndOfMonth().ToDateTimeString() // 2020-08-31 23:59:59// 本周开始时间carbon.Parse("2020-08-05 13:14:15").StartOfWeek(time.Sunday).ToDateTimeString() // 2020-08-02 00:00:00carbon.Parse("2020-08-05 13:14:15").StartOfWeek(time.Monday).ToDateTimeString() // 2020-08-03 00:00:00// 本周结束时间carbon.Parse("2020-08-05 13:14:15").EndOfWeek(time.Sunday).ToDateTimeString() // 2020-08-08 23:59:59carbon.Parse("2020-08-05 13:14:15").EndOfWeek(time.Monday).ToDateTimeString() // 2020-08-09 23:59:59// 本日开始时间carbon.Parse("2020-08-05 13:14:15").StartOfDay().ToDateTimeString() // 2020-08-05 00:00:00// 本日结束时间carbon.Parse("2020-08-05 13:14:15").EndOfDay().ToDateTimeString() // 2020-08-05 23:59:59// 本小时开始时间carbon.Parse("2020-08-05 13:14:15").StartOfHour().ToDateTimeString() // 2020-08-05 13:00:00// 本小时结束时间carbon.Parse("2020-08-05 13:14:15").EndOfHour().ToDateTimeString() // 2020-08-05 13:59:59// 本分钟开始时间carbon.Parse("2020-08-05 13:14:15").StartOfMinute().ToDateTimeString() // 2020-08-05 13:14:00// 本分钟结束时间carbon.Parse("2020-08-05 13:14:15").EndOfMinute().ToDateTimeString() // 2020-08-05 13:14:59// 本秒开始时间carbon.Parse("2020-08-05 13:14:15").StartOfSecond().Format("Y-m-d H:i:s.u") // 2020-08-05 13:14:15.0// 本秒结束时间carbon.Parse("2020-08-05 13:14:15").EndOfSecond().Format("Y-m-d H:i:s.u") // 2020-08-05 13:14:15.999
时间旅行
// 三个世纪后carbon.Parse("2020-02-29 13:14:15").AddCenturies(3).ToDateTimeString() // 2320-02-29 13:14:15// 三个世纪后(月份不溢出)carbon.Parse("2020-02-29 13:14:15").AddCenturiesNoOverflow(3).ToDateTimeString() // 2320-02-29 13:14:15// 一个世纪后carbon.Parse("2020-02-29 13:14:15").AddCentury().ToDateTimeString() // 2120-02-29 13:14:15// 一个世纪后(月份不溢出)carbon.Parse("2020-02-29 13:14:15").AddCenturyNoOverflow().ToDateTimeString() // 2120-02-29 13:14:15// 三个世纪前carbon.Parse("2020-02-29 13:14:15").SubCenturies(3).ToDateTimeString() // 1720-02-29 13:14:15// 三个世纪前(月份不溢出)carbon.Parse("2020-02-29 13:14:15").SubCenturiesNoOverflow(3).ToDateTimeString() // 1720-02-29 13:14:15// 一个世纪前carbon.Parse("2020-02-29 13:14:15").SubCentury().ToDateTimeString() // 1920-02-29 13:14:15// 一世纪前(月份不溢出)carbon.Parse("2020-02-29 13:14:15").SubCenturyNoOverflow().ToDateTimeString() // 1920-02-29 13:14:15// 三个年代后carbon.Parse("2020-02-29 13:14:15").Decades(3).ToDateTimeString() // 2050-03-01 13:14:15// 三个年代后(月份不溢出)carbon.Parse("2020-02-29 13:14:15").AddDecadesNoOverflow(3).ToDateTimeString() // 2050-02-28 13:14:15// 一个年代后carbon.Parse("2020-02-29 13:14:15").AddDecade().ToDateTimeString() // 2030-03-01 13:14:15// 一个年代后(月份不溢出)carbon.Parse("2020-02-29 13:14:15").AddDecadeNoOverflow().ToDateTimeString() // 2030-02-28 13:14:15// 三个年代前carbon.Parse("2020-02-29 13:14:15").SubDecades(3).ToDateTimeString() // 1990-03-01 13:14:15// 三个年代前(月份不溢出)carbon.Parse("2020-02-29 13:14:15").SubDecadesNoOverflow(3).ToDateTimeString() // 1990-02-28 13:14:15// 一个年代前carbon.Parse("2020-02-29 13:14:15").SubDecade().ToDateTimeString() // 2010-03-01 13:14:15// 一个年代前(月份不溢出)carbon.Parse("2020-02-29 13:14:15").SubDecadeNoOverflow().ToDateTimeString() // 2010-02-28 13:14:15// 三年后carbon.Parse("2020-02-29 13:14:15").AddYears(3).ToDateTimeString() // 2023-03-01 13:14:15// 三年后(月份不溢出)carbon.Parse("2020-02-29 13:14:15").AddYearsNoOverflow(3).ToDateTimeString() // 2023-02-28 13:14:15// 一年后carbon.Parse("2020-02-29 13:14:15").AddYear().ToDateTimeString() // 2021-03-01 13:14:15// 一年后(月份不溢出)carbon.Parse("2020-02-29 13:14:15").AddYearNoOverflow().ToDateTimeString() // 2021-02-28 13:14:15// 三年前carbon.Parse("2020-02-29 13:14:15").SubYears(3).ToDateTimeString() // 2017-03-01 13:14:15// 三年前(月份不溢出)carbon.Parse("2020-02-29 13:14:15").SubYearsNoOverflow(3).ToDateTimeString() // 2017-02-28 13:14:15// 一年前carbon.Parse("2020-02-29 13:14:15").SubYear().ToDateTimeString() // 2019-03-01 13:14:15// 一年前(月份不溢出)carbon.Parse("2020-02-29 13:14:15").SubYearNoOverflow().ToDateTimeString() // 2019-02-28 13:14:15// 三个季度后carbon.Parse("2019-08-31 13:14:15").AddQuarters(3).ToDateTimeString() // 2019-03-02 13:14:15// 三个季度后(月份不溢出)carbon.Parse("2019-08-31 13:14:15").AddQuartersNoOverflow(3).ToDateTimeString() // 2019-02-29 13:14:15// 一个季度后carbon.Parse("2019-11-30 13:14:15").AddQuarter().ToDateTimeString() // 2020-03-01 13:14:15// 一个季度后(月份不溢出)carbon.Parse("2019-11-30 13:14:15").AddQuarterNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15// 三个季度前carbon.Parse("2019-08-31 13:14:15").SubQuarters(3).ToDateTimeString() // 2019-03-03 13:14:15// 三个季度前(月份不溢出)carbon.Parse("2019-08-31 13:14:15").SubQuartersNoOverflow(3).ToDateTimeString() // 2019-02-28 13:14:15// 一个季度前carbon.Parse("2020-05-31 13:14:15").SubQuarter().ToDateTimeString() // 2020-03-02 13:14:15// 一个季度前(月份不溢出)carbon.Parse("2020-05-31 13:14:15").SubQuarterNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15// 三个月后carbon.Parse("2020-02-29 13:14:15").AddMonths(3).ToDateTimeString() // 2020-05-29 13:14:15// 三个月后(月份不溢出)carbon.Parse("2020-02-29 13:14:15").AddMonthsNoOverflow(3).ToDateTimeString() // 2020-05-29 13:14:15// 一个月后carbon.Parse("2020-01-31 13:14:15").AddMonth().ToDateTimeString() // 2020-03-02 13:14:15// 一个月后(月份不溢出)carbon.Parse("2020-01-31 13:14:15").AddMonthNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15// 三个月前carbon.Parse("2020-02-29 13:14:15").SubMonths(3).ToDateTimeString() // 2019-11-29 13:14:15// 三个月前(月份不溢出)carbon.Parse("2020-02-29 13:14:15").SubMonthsNoOverflow(3).ToDateTimeString() // 2019-11-29 13:14:15// 一个月前carbon.Parse("2020-03-31 13:14:15").SubMonth().ToDateTimeString() // 2020-03-02 13:14:15// 一个月前(月份不溢出)carbon.Parse("2020-03-31 13:14:15").SubMonthNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15// 三周后carbon.Parse("2020-02-29 13:14:15").AddWeeks(3).ToDateTimeString() // 2020-03-21 13:14:15// 一周后carbon.Parse("2020-02-29 13:14:15").AddWeek().ToDateTimeString() // 2020-03-07 13:14:15// 三周前carbon.Parse("2020-02-29 13:14:15").SubWeeks(3).ToDateTimeString() // 2020-02-08 13:14:15// 一周前carbon.Parse("2020-02-29 13:14:15").SubWeek().ToDateTimeString() // 2020-02-22 13:14:15// 三天后carbon.Parse("2020-08-05 13:14:15").AddDays(3).ToDateTimeString() // 2020-08-08 13:14:15// 一天后carbon.Parse("2020-08-05 13:14:15").AddDay().ToDateTimeString() // 2020-08-05 13:14:15// 三天前carbon.Parse("2020-08-05 13:14:15").SubDays(3).ToDateTimeString() // 2020-08-02 13:14:15// 一天前carbon.Parse("2020-08-05 13:14:15").SubDay().ToDateTimeString() // 2020-08-04 13:14:15// 三小时后carbon.Parse("2020-08-05 13:14:15").AddHours(3).ToDateTimeString() // 2020-08-05 16:14:15// 二小时半后carbon.Parse("2020-08-05 13:14:15").AddDuration("2.5h").ToDateTimeString() // 2020-08-05 15:44:15carbon.Parse("2020-08-05 13:14:15").AddDuration("2h30m").ToDateTimeString() // 2020-08-05 15:44:15// 一小时后carbon.Parse("2020-08-05 13:14:15").AddHour().ToDateTimeString() // 2020-08-05 14:14:15// 三小时前carbon.Parse("2020-08-05 13:14:15").SubHours(3).ToDateTimeString() // 2020-08-05 10:14:15// 二小时半前carbon.Parse("2020-08-05 13:14:15").SubDuration("2.5h").ToDateTimeString() // 2020-08-05 10:44:15carbon.Parse("2020-08-05 13:14:15").SubDuration("2h30m").ToDateTimeString() // 2020-08-05 10:44:15// 一小时前carbon.Parse("2020-08-05 13:14:15").SubHour().ToDateTimeString() // 2020-08-05 12:14:15// 三分钟后carbon.Parse("2020-08-05 13:14:15").AddMinutes(3).ToDateTimeString() // 2020-08-05 13:17:15// 二分钟半后carbon.Parse("2020-08-05 13:14:15").AddDuration("2.5m").ToDateTimeString() // 2020-08-05 13:16:45carbon.Parse("2020-08-05 13:14:15").AddDuration("2m30s").ToDateTimeString() // 2020-08-05 13:16:45// 一分钟后carbon.Parse("2020-08-05 13:14:15").AddMinute().ToDateTimeString() // 2020-08-05 13:15:15// 三分钟前carbon.Parse("2020-08-05 13:14:15").SubMinutes(3).ToDateTimeString() // 2020-08-05 13:11:15// 二分钟半前carbon.Parse("2020-08-05 13:14:15").SubDuration("2.5m").ToDateTimeString() // 2020-08-05 13:11:45carbon.Parse("2020-08-05 13:14:15").SubDuration("2m30s").ToDateTimeString() // 2020-08-05 13:11:45// 一分钟前carbon.Parse("2020-08-05 13:14:15").SubMinute().ToDateTimeString() // 2020-08-05 13:13:15// 三秒钟后carbon.Parse("2020-08-05 13:14:15").AddSeconds(3).ToDateTimeString() // 2020-08-05 13:14:18// 二秒钟半后carbon.Parse("2020-08-05 13:14:15").AddDuration("2.5s").ToDateTimeString() // 2020-08-05 13:14:17// 一秒钟后carbon.Parse("2020-08-05 13:14:15").AddSecond().ToDateTimeString() // 2020-08-05 13:14:16// 三秒钟前carbon.Parse("2020-08-05 13:14:15").SubSeconds(3).ToDateTimeString() // 2020-08-05 13:14:12// 二秒钟半前carbon.Parse("2020-08-05 13:14:15").SubDuration("2.5s").ToDateTimeString() // 2020-08-05 13:14:12// 一秒钟前carbon.Parse("2020-08-05 13:14:15").SubSecond().ToDateTimeString() // 2020-08-05 13:14:14
时间差
// 相差多少年carbon.Parse("2021-08-05 13:14:15").DiffInYears(carbon.Parse("2020-08-05 13:14:15")) // -1// 相差多少年(绝对值)carbon.Parse("2021-08-05 13:14:15").DiffInYearsWithAbs(carbon.Parse("2020-08-05 13:14:15")) // 1// 相差多少月carbon.Parse("2020-08-05 13:14:15").DiffInMonths(carbon.Parse("2020-07-05 13:14:15")) // -1// 相差多少月(绝对值)carbon.Parse("2020-08-05 13:14:15").DiffInMonthsWithAbs(carbon.Parse("2020-07-05 13:14:15")) // 1// 相差多少周carbon.Parse("2020-08-05 13:14:15").DiffInWeeks(carbon.Parse("2020-07-28 13:14:15")) // -1// 相差多少周(绝对值)carbon.Parse("2020-08-05 13:14:15").DiffInWeeksWithAbs(carbon.Parse("2020-07-28 13:14:15")) // 1// 相差多少天carbon.Parse("2020-08-05 13:14:15").DiffInDays(carbon.Parse("2020-08-04 13:14:15")) // -1// 相差多少天(绝对值)carbon.Parse("2020-08-05 13:14:15").DiffInDaysWithAbs(carbon.Parse("2020-08-04 13:14:15")) // 1// 相差多少小时carbon.Parse("2020-08-05 13:14:15").DiffInHours(carbon.Parse("2020-08-05 12:14:15")) // -1// 相差多少小时(绝对值)carbon.Parse("2020-08-05 13:14:15").DiffInHoursWithAbs(carbon.Parse("2020-08-05 12:14:15")) // 1// 相差多少分carbon.Parse("2020-08-05 13:14:15").DiffInMinutes(carbon.Parse("2020-08-05 13:13:15")) // -1// 相差多少分(绝对值)carbon.Parse("2020-08-05 13:14:15").DiffInMinutesWithAbs(carbon.Parse("2020-08-05 13:13:15")) // 1// 相差多少秒carbon.Parse("2020-08-05 13:14:15").DiffInSeconds(carbon.Parse("2020-08-05 13:14:14")) // -1// 相差多少秒(绝对值)carbon.Parse("2020-08-05 13:14:15").DiffInSecondsWithAbs(carbon.Parse("2020-08-05 13:14:14")) // 1// 对人类友好的可读格式时间差carbon.Parse("2020-08-05 13:14:15").DiffForHumans()) // just nowcarbon.Parse("2019-08-05 13:14:15").DiffForHumans() // 1 year agocarbon.Parse("2018-08-05 13:14:15").DiffForHumans() // 2 years agocarbon.Parse("2021-08-05 13:14:15").DiffForHumans() // 1 year from nowcarbon.Parse("2022-08-05 13:14:15").DiffForHumans() // 2 years from nowcarbon.Parse("2020-08-05 13:14:15").DiffForHumans(carbon.Now()) // 1 year beforecarbon.Parse("2019-08-05 13:14:15").DiffForHumans(carbon.Now()) // 2 years beforecarbon.Parse("2018-08-05 13:14:15").DiffForHumans(carbon.Now()) // 1 year aftercarbon.Parse("2022-08-05 13:14:15").DiffForHumans(carbon.Now()) // 2 years after
时间判断
// 是否是零值时间carbon.Parse("").IsZero() // truecarbon.Parse("0").IsZero() // truecarbon.Parse("0000-00-00 00:00:00").IsZero() // truecarbon.Parse("0000-00-00").IsZero() // truecarbon.Parse("00:00:00").IsZero() // truecarbon.Parse("2020-08-05 00:00:00").IsZero() // falsecarbon.Parse("2020-08-05").IsZero() // falsecarbon.Parse("2020-08-05").SetTimezone("xxx").IsZero() // false// 是否是无效时间carbon.Parse("").IsInvalid() // truecarbon.Parse("0").IsInvalid() // truecarbon.Parse("0000-00-00 00:00:00").IsInvalid() // truecarbon.Parse("0000-00-00").IsInvalid() // truecarbon.Parse("00:00:00").IsInvalid() // truecarbon.Parse("2020-08-05 00:00:00").IsInvalid() // falsecarbon.Parse("2020-08-05").IsInvalid() // falsecarbon.Parse("2020-08-05").SetTimezone("xxx").IsInvalid() // true// 是否是当前时间carbon.Now().IsNow() // true// 是否是未来时间carbon.Tomorrow().IsFuture() // true// 是否是过去时间carbon.Yesterday().IsPast() // true// 是否是闰年carbon.Parse("2020-08-05 13:14:15").IsLeapYear() // true// 是否是长年carbon.Parse("2020-08-05 13:14:15").IsLongYear() // true// 是否是一月carbon.Parse("2020-08-05 13:14:15").IsJanuary() // false// 是否是二月carbon.Parse("2020-08-05 13:14:15").IsFebruary() // false// 是否是三月carbon.Parse("2020-08-05 13:14:15").IsMarch() // false// 是否是四月carbon.Parse("2020-08-05 13:14:15").IsApril() // false// 是否是五月carbon.Parse("2020-08-05 13:14:15").IsMay() // false// 是否是六月carbon.Parse("2020-08-05 13:14:15").IsJune() // false// 是否是七月carbon.Parse("2020-08-05 13:14:15").IsJuly() // false// 是否是八月carbon.Parse("2020-08-05 13:14:15").IsAugust() // false// 是否是九月carbon.Parse("2020-08-05 13:14:15").IsSeptember() // true// 是否是十月carbon.Parse("2020-08-05 13:14:15").IsOctober() // false// 是否是十一月carbon.Parse("2020-08-05 13:14:15").IsNovember() // false// 是否是十二月carbon.Parse("2020-08-05 13:14:15").IsDecember() // false// 是否是周一carbon.Parse("2020-08-05 13:14:15").IsMonday() // false// 是否是周二carbon.Parse("2020-08-05 13:14:15").IsTuesday() // true// 是否是周三carbon.Parse("2020-08-05 13:14:15").IsWednesday() // false// 是否是周四carbon.Parse("2020-08-05 13:14:15").IsThursday() // false// 是否是周五carbon.Parse("2020-08-05 13:14:15").IsFriday() // false// 是否是周六carbon.Parse("2020-08-05 13:14:15").IsSaturday() // false// 是否是周日carbon.Parse("2020-08-05 13:14:15").IsSunday() // false// 是否是工作日carbon.Parse("2020-08-05 13:14:15").IsWeekday() // false// 是否是周末carbon.Parse("2020-08-05 13:14:15").IsWeekend() // true// 是否是昨天carbon.Parse("2020-08-04 13:14:15").IsYesterday() // truecarbon.Parse("2020-08-04 00:00:00").IsYesterday() // truecarbon.Parse("2020-08-04").IsYesterday() // true// 是否是今天carbon.Parse("2020-08-05 13:14:15").IsToday() // truecarbon.Parse("2020-08-05 00:00:00").IsToday() // truecarbon.Parse("2020-08-05").IsToday() // true// 是否是明天carbon.Parse("2020-08-06 13:14:15").IsTomorrow() // truecarbon.Parse("2020-08-06 00:00:00").IsTomorrow() // truecarbon.Parse("2020-08-06").IsTomorrow() // true// 是否大于carbon.Parse("2020-08-05 13:14:15").Gt(carbon.Parse("2020-08-04 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Gt(carbon.Parse("2020-08-05 13:14:15")) // falsecarbon.Parse("2020-08-05 13:14:15").Compare(">", carbon.Parse("2020-08-04 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare(">", carbon.Parse("2020-08-05 13:14:15")) // false// 是否小于carbon.Parse("2020-08-05 13:14:15").Lt(carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Lt(carbon.Parse("2020-08-05 13:14:15")) // falsecarbon.Parse("2020-08-05 13:14:15").Compare("<", carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare("<", carbon.Parse("2020-08-05 13:14:15")) // false// 是否等于carbon.Parse("2020-08-05 13:14:15").Eq(carbon.Parse("2020-08-05 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Eq(carbon.Parse("2020-08-05 13:14:00")) // falsecarbon.Parse("2020-08-05 13:14:15").Compare("=", carbon.Parse("2020-08-05 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare("=", carbon.Parse("2020-08-05 13:14:00")) // false// 是否不等于carbon.Parse("2020-08-05 13:14:15").Ne(carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Ne(carbon.Parse("2020-08-05 13:14:15")) // falsecarbon.Parse("2020-08-05 13:14:15").Compare("!=", carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare("<>", carbon.Parse("2020-08-05 13:14:15")) // false// 是否大于等于carbon.Parse("2020-08-05 13:14:15").Gte(carbon.Parse("2020-08-04 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Gte(carbon.Parse("2020-08-05 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare(">=", carbon.Parse("2020-08-04 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare(">=", carbon.Parse("2020-08-05 13:14:15")) // true// 是否小于等于carbon.Parse("2020-08-05 13:14:15").Lte(carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Lte(carbon.Parse("2020-08-05 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare("<=", carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").Compare("<=", carbon.Parse("2020-08-05 13:14:15")) // true// 是否在两个时间之间(不包括这两个时间)carbon.Parse("2020-08-05 13:14:15").Between(carbon.Parse("2020-08-05 13:14:15"), carbon.Parse("2020-08-06 13:14:15")) // falsecarbon.Parse("2020-08-05 13:14:15").Between(carbon.Parse("2020-08-04 13:14:15"), carbon.Parse("2020-08-06 13:14:15")) // true// 是否在两个时间之间(包括开始时间)carbon.Parse("2020-08-05 13:14:15").BetweenIncludedStart(carbon.Parse("2020-08-05 13:14:15"), carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").BetweenIncludedStart(carbon.Parse("2020-08-04 13:14:15"), carbon.Parse("2020-08-06 13:14:15")) // true// 是否在两个时间之间(包括结束时间)carbon.Parse("2020-08-05 13:14:15").BetweenIncludedEnd(carbon.Parse("2020-08-04 13:14:15"), carbon.Parse("2020-08-05 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").BetweenIncludedEnd(carbon.Parse("2020-08-04 13:14:15"), carbon.Parse("2020-08-06 13:14:15")) // true// 是否在两个时间之间(包括这两个时间)carbon.Parse("2020-08-05 13:14:15").BetweenIncludedBoth(carbon.Parse("2020-08-05 13:14:15"), carbon.Parse("2020-08-06 13:14:15")) // truecarbon.Parse("2020-08-05 13:14:15").BetweenIncludedBoth(carbon.Parse("2020-08-04 13:14:15"), carbon.Parse("2020-08-05 13:14:15")) // true

关于长年(LongYear)的定义, 请查看 https://en.wikipedia.org/wiki/ISO_8601#Week_dates

时间设置
// 设置时区carbon.SetTimezone(carbon.PRC).Now().ToDateTimeString() // 2020-08-05 13:14:15carbon.SetTimezone(carbon.Tokyo).Now().ToDateTimeString() // 2020-08-05 14:14:15carbon.SetTimezone(carbon.Tokyo).Now().SetTimezone(carbon.PRC).ToDateTimeString() // 2020-08-05 12:14:15// 设置区域carbon.Parse("2020-07-05 13:14:15").SetLocale("en").DiffForHumans() // 1 month agocarbon.Parse("2020-07-05 13:14:15").SetLocale("zh-CN").DiffForHumans() // 1 月前// 设置年份carbon.Parse("2020-02-29").SetYear(2021).ToDateString() // 2021-03-01// 设置年份(月份不溢出)carbon.Parse("2020-02-29").SetYearNoOverflow(2021).ToDateString() // 2021-02-28// 设置月份carbon.Parse("2020-01-31").SetMonth(2).ToDateString() // 2020-03-02// 设置月份(月份不溢出)carbon.Parse("2020-01-31").SetMonthNoOverflow(2).ToDateString() // 2020-02-29// 设置日期carbon.Parse("2019-08-05").SetDay(31).ToDateString() // 2020-08-31carbon.Parse("2020-02-01").SetDay(31).ToDateString() // 2020-03-02// 设置小时carbon.Parse("2020-08-05 13:14:15").SetHour(10).ToDateTimeString() // 2020-08-05 10:14:15carbon.Parse("2020-08-05 13:14:15").SetHour(24).ToDateTimeString() // 2020-08-06 00:14:15// 设置分钟carbon.Parse("2020-08-05 13:14:15").SetMinute(10).ToDateTimeString() // 2020-08-05 13:10:15carbon.Parse("2020-08-05 13:14:15").SetMinute(60).ToDateTimeString() // 2020-08-05 14:00:15// 设置秒carbon.Parse("2020-08-05 13:14:15").SetSecond(10).ToDateTimeString() // 2020-08-05 13:14:10carbon.Parse("2020-08-05 13:14:15").SetSecond(60).ToDateTimeString() // 2020-08-05 13:15:00// 设置毫秒carbon.Parse("2020-08-05 13:14:15").SetMillisecond(100).Millisecond() // 100carbon.Parse("2020-08-05 13:14:15").SetMillisecond(999).Millisecond() // 999// 设置微妙carbon.Parse("2020-08-05 13:14:15").SetMicrosecond(100000).Microsecond() // 100000carbon.Parse("2020-08-05 13:14:15").SetMicrosecond(999999).Microsecond() // 999999// 设置纳秒carbon.Parse("2020-08-05 13:14:15").SetNanosecond(100000000).Nanosecond() // 100000000carbon.Parse("2020-08-05 13:14:15").SetNanosecond(999999999).Nanosecond() // 999999999
时间获取
// 获取本年总天数carbon.Parse("2019-08-05 13:14:15").DaysInYear() // 365carbon.Parse("2020-08-05 13:14:15").DaysInYear() // 366// 获取本月总天数carbon.Parse("2020-02-01 13:14:15").DaysInMonth() // 29carbon.Parse("2020-04-01 13:14:15").DaysInMonth() // 30carbon.Parse("2020-08-01 13:14:15").DaysInMonth() // 31// 获取本年第几天carbon.Parse("2020-08-05 13:14:15").DayOfYear() // 218// 获取本年第几周carbon.Parse("2019-12-31 13:14:15").WeekOfYear() // 1carbon.Parse("2020-08-05 13:14:15").WeekOfYear() // 32// 获取本月第几天carbon.Parse("2020-08-05 13:14:15").DayOfMonth() // 5// 获取本月第几周carbon.Parse("2020-08-05 13:14:15").WeekOfMonth() // 1// 获取本周第几天carbon.Parse("2020-08-05 13:14:15").DayOfWeek() // 3carbon.Parse("2020-08-09 13:14:15").Week() // 7// 获取当前世纪carbon.Parse("2020-08-05 13:14:15").Century() // 21// 获取当前年代carbon.Parse("2019-08-05 13:14:15").Decade() // 10carbon.Parse("2021-08-05 13:14:15").Decade() // 20// 获取当前年份carbon.Parse("2020-08-05 13:14:15").Year() // 2020// 获取当前季度carbon.Parse("2020-08-05 13:14:15").Quarter() // 3// 获取当前月份carbon.Parse("2020-08-05 13:14:15").Month() // 8// 获取当前周(从0开始)carbon.Parse("2020-08-05 13:14:15").Week() // 3carbon.Parse("2020-08-09 13:14:15").Week() // 0// 获取当前天数carbon.Parse("2020-08-05 13:14:15").Day() // 5// 获取当前小时carbon.Parse("2020-08-05 13:14:15").Hour() // 13// 获取当前分钟carbon.Parse("2020-08-05 13:14:15").Minute() // 14// 获取当前秒钟carbon.Parse("2020-08-05 13:14:15").Second() // 15// 获取当前毫秒carbon.Parse("2020-08-05 13:14:15").Millisecond() // 1596604455000// 获取当前微秒carbon.Parse("2020-08-05 13:14:15").Microsecond() // 1596604455000000// 获取当前纳秒carbon.Parse("2020-08-05 13:14:15").Nanosecond() // 1596604455000000000// 获取时区carbon.SetTimezone(carbon.PRC).Timezone() // CSTcarbon.SetTimezone(carbon.Tokyo).Timezone() // JST// 获取位置carbon.SetTimezone(carbon.PRC).Location() // PRCcarbon.SetTimezone(carbon.Tokyo).Location() // Asia/Tokyo// 获取距离UTC时区的偏移量,单位秒carbon.SetTimezone(carbon.PRC).Offset() // 28800carbon.SetTimezone(carbon.Tokyo).Offset() // 32400// 获取当前区域carbon.Now().Locale() // encarbon.Now().SetLocale("zh-CN").Locale() // zh-CN// 获取当前星座carbon.Now().Constellation() // Leocarbon.Now().SetLocale("en").Constellation() // Leocarbon.Now().SetLocale("zh-CN").Constellation() // 狮子座// 获取当前季节carbon.Now().Season() // Summercarbon.Now().SetLocale("en").Season() // Summercarbon.Now().SetLocale("zh-CN").Season() // 夏季// 获取年龄carbon.Parse("2002-01-01 13:14:15").Age() // 17carbon.Parse("2002-12-31 13:14:15").Age() // 18
时间输出
// 输出秒级时间戳, ToTimestamp() 是ToTimestampWithSecond()的简写carbon.Parse("2020-08-05 13:14:15").ToTimestamp() // 1596604455carbon.Parse("2020-08-05 13:14:15").ToTimestampWithSecond() // 1596604455// 输出毫秒级时间戳carbon.Parse("2020-08-05 13:14:15").ToTimestampWithMillisecond() // 1596604455000// 输出微秒级时间戳carbon.Parse("2020-08-05 13:14:15").ToTimestampWithMicrosecond() // 1596604455000000// 输出纳秒级时间戳carbon.Parse("2020-08-05 13:14:15").ToTimestampWithNanosecond() // 1596604455000000000// 输出日期时间字符串carbon.Parse("2020-08-05 13:14:15").ToDateTimeString() // 2020-08-05 13:14:15carbon.Parse("2020-08-05 13:14:15").ToDateTimeString(carbon.Tokyo) // 2020-08-05 14:14:15// 输出简写日期时间字符串carbon.Parse("2020-08-05 13:14:15").ToShortDateTimeString() // 20200805131415carbon.Parse("2020-08-05 13:14:15").ToShortDateTimeString(carbon.Tokyo) // 20200805141415// 输出日期字符串carbon.Parse("2020-08-05 13:14:15").ToDateString() // 2020-08-05carbon.Parse("2020-08-05 13:14:15").ToDateString(carbon.Tokyo) // 2020-08-05// 输出简写日期字符串carbon.Parse("2020-08-05 13:14:15").ToShortDateString() // 20200805carbon.Parse("2020-08-05 13:14:15").ToShortDateString(carbon.Tokyo) // 20200805// 输出时间字符串carbon.Parse("2020-08-05 13:14:15").ToTimeString() // 13:14:15carbon.Parse("2020-08-05 13:14:15").ToTimeString(carbon.Tokyo) // 14:14:15// 输出简写时间字符串carbon.Parse("2020-08-05 13:14:15").ToShortTimeString() // 131415carbon.Parse("2020-08-05 13:14:15").ToShortTimeString(carbon.Tokyo) // 141415// 输出 Ansic 格式字符串carbon.Parse("2020-08-05 13:14:15").ToAnsicString() // Wed Aug 5 13:14:15 2020carbon.Parse("2020-08-05 13:14:15").ToAnsicString(carbon.Tokyo) // Wed Aug 5 14:14:15 2020// 输出 Atom 格式字符串carbon.Parse("2020-08-05 13:14:15").ToAtomString() // 2020-08-05T13:14:15+08:00carbon.Parse("2020-08-05 13:14:15").ToAtomString(carbon.Tokyo) // 2020-08-05T14:14:15+08:00// 输出 UnixDate 格式字符串carbon.Parse("2020-08-05 13:14:15").ToUnixDateString() // Wed Aug 5 13:14:15 CST 2020carbon.Parse("2020-08-05 13:14:15").ToUnixDateString(carbon.Tokyo) // Wed Aug 5 14:14:15 JST 2020// 输出 RubyDate 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRubyDateString() // Wed Aug 05 13:14:15 +0800 2020carbon.Parse("2020-08-05 13:14:15").ToRubyDateString(carbon.Tokyo) // Wed Aug 05 14:14:15 +0900 2020// 输出 Kitchen 格式字符串carbon.Parse("2020-08-05 13:14:15").ToKitchenString() // 1:14PMcarbon.Parse("2020-08-05 13:14:15").ToKitchenString(carbon.Tokyo) // 2:14PM// 输出 Cookie 格式字符串carbon.Parse("2020-08-05 13:14:15").ToCookieString() // Wednesday, 05-Aug-2020 13:14:15 CSTcarbon.Parse("2020-08-05 13:14:15").ToCookieString(carbon.Tokyo) // Wednesday, 05-Aug-2020 14:14:15 JST// 输出 DayDateTime 格式字符串carbon.Parse("2020-08-05 13:14:15").ToDayDateTimeString() // Wed, Aug 5, 2020 1:14 PMcarbon.Parse("2020-08-05 13:14:15").ToDayDateTimeString(carbon.Tokyo) // Wed, Aug 5, 2020 2:14 PM// 输出 RSS 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRssString() // Wed, 05 Aug 2020 13:14:15 +0800carbon.Parse("2020-08-05 13:14:15").ToRssString(carbon.Tokyo) // Wed, 05 Aug 2020 14:14:15 +0900// 输出 W3C 格式字符串carbon.Parse("2020-08-05 13:14:15").ToW3cString() // 2020-08-05T13:14:15+08:00carbon.Parse("2020-08-05 13:14:15").ToW3cString(carbon.Tokyo) // 2020-08-05T14:14:15+09:00// 输出 ISO8601 格式字符串carbon.Parse("2020-08-05 13:14:15").ToIso8601String() // 2020-08-05T13:14:15+08:00carbon.Parse("2020-08-05 13:14:15").ToIso8601String(carbon.Tokyo) // 2020-08-05T14:14:15+09:00// 输出 RFC822 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc822String() // 05 Aug 20 13:14 CSTcarbon.Parse("2020-08-05 13:14:15").ToRfc822String(carbon.Tokyo) // 05 Aug 20 14:14 JST// 输出 RFC822Z 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc822zString() // 05 Aug 20 13:14 +0800carbon.Parse("2020-08-05 13:14:15").ToRfc822zString(carbon.Tokyo) // 05 Aug 20 14:14 +0900// 输出 RFC850 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc850String() // Wednesday, 05-Aug-20 13:14:15 CSTcarbon.Parse("2020-08-05 13:14:15").ToRfc850String(carbon.Tokyo) // Wednesday, 05-Aug-20 14:14:15 JST// 输出 RFC1036 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc1036String() // Wed, 05 Aug 20 13:14:15 +0800carbon.Parse("2020-08-05 13:14:15").ToRfc1036String(carbon.Tokyo) // Wed, 05 Aug 20 14:14:15 +0900// 输出 RFC1123 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc1123String() // Wed, 05 Aug 2020 13:14:15 CSTcarbon.Parse("2020-08-05 13:14:15").ToRfc1123String(carbon.Tokyo) // Wed, 05 Aug 2020 14:14:15 JST// 输出 RFC1123Z 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc1123zString() // Wed, 05 Aug 2020 13:14:15 +0800carbon.Parse("2020-08-05 13:14:15").ToRfc1123zString(carbon.Tokyo) // Wed, 05 Aug 2020 14:14:15 0800// 输出 RFC2822 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc2822String() // Wed, 05 Aug 2020 13:14:15 +0800carbon.Parse("2020-08-05 13:14:15").ToRfc2822String(carbon.Tokyo) // Wed, 05 Aug 2020 14:14:15 +0900// 输出 RFC3339 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc3339String() // 2020-08-05T13:14:15+08:00carbon.Parse("2020-08-05 13:14:15").ToRfc3339String(carbon.Tokyo) // 2020-08-05T14:14:15+09:00// 输出 RFC7231 格式字符串carbon.Parse("2020-08-05 13:14:15").ToRfc7231String() // Wed, 05 Aug 2020 13:14:15 GMTcarbon.Parse("2020-08-05 13:14:15").ToRfc7231String(carbon.Tokyo) // Wed, 05 Aug 2020 14:14:15 GMT// 输出日期时间字符串fmt.Sprintf("%s", carbon.Parse("2020-08-05 13:14:15")) // 2020-08-05 13:14:15fmt.Sprintf("%s", carbon.Parse("2020-08-05 13:14:15", carbon.Tokyo)) // 2020-08-05 13:14:15// 输出"2006-01-02 15:04:05.999999999 -0700 MST"格式字符串carbon.Parse("2020-08-05 13:14:15").ToString() // 2020-08-05 13:14:15 +0800 CSTcarbon.Parse("2020-08-05 13:14:15").ToString(carbon.Tokyo) // 2020-08-05 14:14:15 +0900 JST// 输出指定布局的字符串,Layout()是ToLayoutString()的简写carbon.Parse("2020-08-05 13:14:15").Layout("20060102150405") // 20200805131415carbon.Parse("2020-08-05 13:14:15").Layout("2006年01月02日 15时04分05秒") // 2020年08月05日 13时14分15秒carbon.Parse("2020-08-05 13:14:15").Layout("It is 2006-01-02 15:04:05") // It is 2020-08-05 13:14:15carbon.Parse("2020-08-05 13:14:15").Layout("2006-01-02 15:04:05", carbon.Tokyo) // 2020-08-05 14:14:15// 输出指定格式的字符串,Format()是ToFormatString()的简写(如果使用的字母与格式化字符冲突时,请使用\符号转义该字符)carbon.Parse("2020-08-05 13:14:15").Format("YmdHis") // 20200805131415carbon.Parse("2020-08-05 13:14:15").Format("Y年m月d日 H时i分s秒") // 2020年08月05日 13时14分15秒carbon.Parse("2020-08-05 13:14:15").Format("l jS \\o\\f F Y h:i:s A") // Wednesday 5th of August 2020 01:14:15 PMcarbon.Parse("2020-08-05 13:14:15").Format("\\I\\t \\i\\s Y-m-d H:i:s") // It is 2020-08-05 13:14:15carbon.Parse("2020-08-05 13:14:15").Format("Y-m-d H:i:s", carbon.Tokyo) // 2020-08-05 14:14:15

更多格式化输出符号请查看附录 格式化符号表

星座
// 获取星座carbon.Parse("2020-08-05 13:14:15").Constellation() // Leo// 是否是白羊座carbon.Parse("2020-08-05 13:14:15").IsAries() // false// 是否是金牛座carbon.Parse("2020-08-05 13:14:15").IsTaurus() // false// 是否是双子座carbon.Parse("2020-08-05 13:14:15").IsGemini() // false// 是否是巨蟹座carbon.Parse("2020-08-05 13:14:15").IsCancer() // false// 是否是狮子座carbon.Parse("2020-08-05 13:14:15").IsLeo() // true// 是否是处女座carbon.Parse("2020-08-05 13:14:15").IsVirgo() // false// 是否是天秤座carbon.Parse("2020-08-05 13:14:15").IsLibra() // false// 是否是天蝎座carbon.Parse("2020-08-05 13:14:15").IsScorpio() // false// 是否是射手座carbon.Parse("2020-08-05 13:14:15").IsSagittarius() // false// 是否是摩羯座carbon.Parse("2020-08-05 13:14:15").IsCapricorn() // false// 是否是水瓶座carbon.Parse("2020-08-05 13:14:15").IsAquarius() // false// 是否是双鱼座carbon.Parse("2020-08-05 13:14:15").IsPisces() // false
季节

按照气象划分,即3-5月为春季,6-8月为夏季,9-11月为秋季,12-2月为冬季

// 获取季节carbon.Parse("2020-08-05 13:14:15").Season() // Summer// 本季节开始时间carbon.Parse("2020-08-05 13:14:15").StartOfSeason().ToDateTimeString() // 2020-06-01 00:00:00// 本季节结束时间carbon.Parse("2020-08-05 13:14:15").EndOfSeason().ToDateTimeString() // 2020-08-31 23:59:59// 是否是春季carbon.Parse("2020-08-05 13:14:15").IsSpring() // false// 是否是夏季carbon.Parse("2020-08-05 13:14:15").IsSummer() // true// 是否是秋季carbon.Parse("2020-08-05 13:14:15").IsAutumn() // false// 是否是冬季carbon.Parse("2020-08-05 13:14:15").IsWinter() // false
农历

目前仅支持公元1900年至2100年的200年时间跨度

// 获取农历生肖carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().Animal() // 鼠// 获取农历节日carbon.Parse("2021-02-12 13:14:15", carbon.PRC).Lunar().Festival() // 春节// 获取农历年年份carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().Year() // 2020// 获取农历月月份carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().Month() // 6// 获取农历闰月月份carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().LeapMonth() // 4// 获取农历日日期carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().Day() // 16// 获取农历 YYYY-MM-DD 格式字符串fmt.Sprintf("%s", carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar()) // 2020-06-16// 获取农历年字符串carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().ToYearString() // 二零二零// 获取农历月字符串carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().ToMonthString() // 六// 获取农历天字符串carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().ToDayString() // 十六// 获取农历日期字符串carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().ToDateString() // 二零二零年六月十六// 是否是农历闰年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsLeapYear() // true// 是否是农历闰月carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsLeapMonth() // false// 是否是鼠年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsRatYear() // true// 是否是牛年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsOxYear() // false// 是否是虎年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsTigerYear() // false// 是否是兔年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsRabbitYear() // false// 是否是龙年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsDragonYear() // false// 是否是蛇年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsSnakeYear() // false// 是否是马年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsHorseYear() // false// 是否是羊年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsGoatYear() // false// 是否是猴年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsMonkeyYear() // false// 是否是鸡年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsRoosterYear() // false// 是否是狗年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsDogYear() // false// 是否是猪年carbon.Parse("2020-08-05 13:14:15", carbon.PRC).Lunar().IsPigYear() // false
JSON 支持
定义模型
type Person struct { ID int64 `json:"id"` Name string `json:"name"` Age int `json:"age"` Birthday carbon.ToDateTimeString `json:"birthday"` GraduatedAt carbon.ToDateString `json:"graduated_at"` CreatedAt carbon.ToTimeString `json:"created_at"` UpdatedAt carbon.ToTimestamp `json:"updated_at"` DateTime1 carbon.ToTimestampWithSecond `json:"date_time1"` DateTime2 carbon.ToTimestampWithMillisecond `json:"date_time2"` DateTime3 carbon.ToTimestampWithMicrosecond `json:"date_time3"` DateTime4 carbon.ToTimestampWithNanosecond `json:"date_time4"`}
实例化模型
person := Person { ID: 1, Name: "gouguoyin", Age: 18, Birthday: carbon.ToDateTimeString{carbon.Now().SubYears(18)}, GraduatedAt: carbon.ToDateString{carbon.Parse("2020-08-05 13:14:15")}, CreatedAt: carbon.ToTimeString{carbon.Parse("2021-08-05 13:14:15")}, UpdatedAt: carbon.ToTimestamp{carbon.Parse("2022-08-05 13:14:15")}, DateTime1: carbon.ToTimestampWithSecond{carbon.Parse("2023-08-05 13:14:15")}, DateTime2: carbon.ToTimestampWithMillisecond{carbon.Parse("2024-08-05 13:14:15")}, DateTime3: carbon.ToTimestampWithMicrosecond{carbon.Parse("2025-08-05 13:14:15")}, DateTime4: carbon.ToTimestampWithNanosecond{carbon.Parse("2025-08-05 13:14:15")},}
JSON 编码
data, err := json.Marshal(&person)if err != nil {t.Fatal(err)}fmt.Printf("%s",data)// 输出{"id":1,"name":"gouguoyin","age":18,"birthday":"2003-07-16 16:22:02","graduated_at":"2020-08-05","created_at":"13:14:15","updated_at":1659676455,"date_time1":1691212455,"date_time2":1722834855000,"date_time3":1754370855000000,"date_time4":1754370855000000000}
JSON 解码
jsonString := `{"id":1,"name":"gouguoyin","age":18,"birthday":"2003-07-16 16:22:02","graduated_at":"2020-08-05","updated_at":1659676455,"date_time1":1691212455,"date_time2":1722834855000,"date_time3":1754370855000000,"date_time4":1754370855000000000}`person := new(Person)err := json.Unmarshal([]byte(jsonString), &person)if err != nil {t.Fatal(err)}fmt.Printf("%+v", *person)// 输出{ID:1 Name:gouguoyin Age:18 Birthday:2003-07-16 16:22:02 GraduatedAt:2020-08-05 00:00:00 UpdatedAt:2022-08-05 13:14:15 DTime1:2023-08-05 13:14:15 DateTime2:2024-08-05 13:14:15 DateTime3:2025-08-05 13:14:15 DateTime4:2025-08-05 13:14:15}
国际化支持

目前支持的语言有

目前支持的方法有

  • Constellation():获取星座
  • Season():获取季节
  • DiffForHumans():获取对人类友好的可读格式时间差
  • ToMonthString():输出完整月份字符串
  • ToShortMonthString():输出缩写月份字符串
  • ToWeekString():输出完整星期字符串
  • ToShortWeekString():输出缩写星期字符串
设置区域
lang := NewLanguage()if err := lang.SetLocale("zh-CN");err != nil {// 错误处理 log.Fatal(err)}c := carbon.SetLanguage(lang)c.Now().AddHours(1).DiffForHumans() // 1 小时后c.Now().AddHours(1).ToMonthString() // 八月c.Now().AddHours(1).ToShortMonthString() // 8月c.Now().AddHours(1).ToWeekString() // 星期二c.Now().AddHours(1).ToShortWeekString() // 周二c.Now().AddHours(1).Constellation() // 狮子座c.Now().AddHours(1).Season() // 夏季
重写部分翻译资源(其余仍然按照指定的 locale 文件内容翻译)
lang := NewLanguage()if err := lang.SetLocale("en");err != nil {// 错误处理 log.Fatal(err)}resources := map[string]string { "hour":"%dh",}lang.SetResources(resources)c := carbon.SetLanguage(lang)c.Now().AddYears(1).DiffForHumans() // 1 year from nowc.Now().AddHours(1).DiffForHumans() // 1h from nowc.Now().ToMonthString() // Augustc.Now().ToShortMonthString() // Augc.Now().ToWeekString() // Tuesdayc.Now().ToShortWeekString() // Tuec.Now().Constellation() // Leoc.Now().Season() // Summer
重写全部翻译资源(无需指定 locale)
lang := NewLanguage()resources := map[string]string { "months": "January|February|March|April|May|June|July|August|September|October|November|December", "months_short": "Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec", "weeks": "Sunday|Monday|Tuesday|Wednesday|Thursday|Friday|Saturday", "weeks_short": "Sun|Mon|Tue|Wed|Thu|Fri|Sat", "seasons": "Spring|Summer|Autumn|Winter", "constellations": "Aries|Taurus|Gemini|Cancer|Leo|Virgo|Libra|Scorpio|Sagittarius|Capricornus|Aquarius|Pisce", "year":"1 yr|%d yrs", "month":"1 mo|%d mos", "week":"%dw", "day":"%dd", "hour":"%dh", "minute":"%dm", "second":"%ds", "now": "just now", "ago":"%s ago", "from_now":"in %s", "before":"%s before", "after":"%s after",}lang.SetResources(resources)c := carbon.SetLanguage(lang)c.Now().AddYears(1).DiffForHumans() // in 1 yrc.Now().AddHours(1).DiffForHumans() // in 1hc.Now().ToMonthString() // Augustc.Now().ToShortMonthString() // Augc.Now().ToWeekString() // Tuesdayc.Now().ToShortWeekString() // Tuec.Now().Constellation() // Leoc.Now().Season() // Summer
错误处理

如果有多个错误发生,只返回第一个错误,前一个错误排除后才返回下一个错误

场景一
c := carbon.SetTimezone(PRC).Parse("xxx")if c.Error != nil { // 错误处理... log.Fatal(c.Error)}fmt.Println(c.ToDateTimeString())// 输出cannot parse "xxx" as carbon, please make sure the value is valid
场景二
c := carbon.SetTimezone("xxx").Parse("2020-08-05")if c.Error != nil { // 错误处理... log.Fatal(c.Error)}fmt.Println(c.ToDateTimeString())// 输出invalid timezone "xxx", please see the file "$GOROOT/lib/time/zoneinfo.zip" for all valid timezones
场景三
c := carbon.SetTimezone("xxx").Parse("12345678")if c.Error != nil { // 错误处理... log.Fatal(c.Error)}fmt.Println(c.ToDateTimeString())// 输出invalid timezone "xxx", please see the file "$GOROOT/lib/time/zoneinfo.zip" for all valid timezone

附录

格式化符号表
符号描述长度范围示例
d月份中的第几天,有前导零201-3105
D缩写单词表示的周几3Mon-SunWed
j月份中的第几天,没有前导零-1-315
S第几天的英文缩写后缀,一般和j配合使用2st/nd/rd/thth
l完整单词表示的周几-Monday-SundayWednesday
F完整单词表示的月份-January-DecemberAugust
m数字表示的月份,有前导零201-1208
M缩写单词表示的月份3Jan-DecAug
n数字表示的月份-1-128
Y4 位数字完整表示的年份40000-999992020
y2 位数字表示的年份40000-999920
a小写的上午和下午标识2am/pmpm
A大写的上午和下午标识2AM/PMPM
g小时,12 小时格式-1-121
G小时,24 小时格式-0-2315
h小时,12 小时格式200-1103
H小时,24 小时格式200-2315
i分钟201-5914
s秒数201-5915
cISO8601 格式日期--2020-08-05T15:19:21+00:00
rRFC822 格式日期--Thu, 21 Dec 2020 16:01:07 +0200
O与格林威治时间相差的小时数--+0200
P与格林威治时间相差的小时数,小时和分钟之间有冒号分隔--+02:00
T时区缩写--EST
WISO8601 格式数字表示的年份中的第几周-1-5242
NISO8601 格式数字表示的星期中的第几天11-76
L是否为闰年,如果是闰年为 1,否则为 010-11
U秒级时间戳10-1611818268
u毫秒3000-999999
w数字表示的周几10-66
t月份中的总天数228-3130
z年份中的第几天-0-36515
e当前位置--America/New_York
Q当前季节11-41
C当前世纪数-0-9921

参考项目