carbon/README.cn.md

1513 lines
68 KiB
Markdown
Raw Normal View History

# Carbon #
2021-08-16 09:34:15 +08:00
2021-07-31 18:33:39 +08:00
[![Carbon Release](https://img.shields.io/github/release/golang-module/carbon.svg)](https://github.com/golang-module/carbon/releases)
2021-08-09 22:38:26 +08:00
[![Go Test](https://github.com/golang-module/carbon/actions/workflows/test.yml/badge.svg)](https://github.com/golang-module/carbon/actions)
2021-07-23 11:05:33 +08:00
[![Go Report Card](https://goreportcard.com/badge/github.com/golang-module/carbon)](https://goreportcard.com/report/github.com/golang-module/carbon)
2021-08-09 22:38:26 +08:00
[![Go Coverage](https://codecov.io/gh/golang-module/carbon/branch/master/graph/badge.svg)](https://codecov.io/gh/golang-module/carbon)
2021-07-31 13:08:43 +08:00
[![Carbon Doc](https://img.shields.io/badge/go.dev-reference-brightgreen?logo=go&logoColor=white&style=flat)](https://pkg.go.dev/github.com/golang-module/carbon)
![License](https://img.shields.io/github/license/golang-module/carbon)
2021-07-23 11:05:33 +08:00
2021-08-16 09:34:15 +08:00
简体中文 | [English](README.md) | [日本語](README.jp.md)
2020-09-07 17:10:33 +08:00
2021-08-05 19:36:51 +08:00
一个轻量级、语义化、对开发者友好的 golang 时间处理库,支持链式调用
2021-08-02 12:26:33 +08:00
2021-08-02 14:03:48 +08:00
Carbon 已被 [awesome-go](https://github.com/avelino/awesome-go#date-and-time "awesome-go") 收录, 如果您觉得不错,请给个 star 吧
2020-09-07 17:32:25 +08:00
2021-08-09 16:47:20 +08:00
[github.com/golang-module/carbon](https://github.com/golang-module/carbon "github.com/golang-module/carbon")
2020-09-07 17:32:25 +08:00
2022-05-04 23:55:39 +08:00
[gitee.com/golang-module/carbon](https://gitee.com/golang-module/carbon "gitee.com/golang-module/carbon")
2020-10-07 17:15:46 +08:00
#### 安装使用
2021-08-16 09:34:15 +08:00
2022-05-07 09:16:36 +08:00
##### Golang 版本大于等于 1.16
2021-09-06 11:13:43 +08:00
2020-10-07 17:15:46 +08:00
```go
// 使用 github 库
2022-05-07 09:16:36 +08:00
go get -u github.com/golang-module/carbon/v2
2020-10-07 17:15:46 +08:00
import (
2022-05-07 09:16:36 +08:00
"github.com/golang-module/carbon/v2"
2020-10-07 17:15:46 +08:00
)
// 使用 gitee 库
2022-05-07 09:16:36 +08:00
go get -u gitee.com/golang-module/carbon/v2
2020-10-07 17:15:46 +08:00
import (
2022-05-07 10:28:54 +08:00
"gitee.com/golang-module/carbon/v2"
)
2020-10-07 17:15:46 +08:00
```
2022-05-07 09:16:36 +08:00
##### Golang 版本小于 1.16
2021-09-15 21:02:59 +08:00
```go
// 使用 github 库
2022-05-07 09:16:36 +08:00
go get -u github.com/golang-module/carbon
2021-09-15 21:02:59 +08:00
import (
2022-05-20 00:02:30 +08:00
"github.com/golang-module/carbon"
2021-09-15 21:02:59 +08:00
)
// 使用 gitee 库
2022-05-07 09:16:36 +08:00
go get -u gitee.com/golang-module/carbon
2021-09-15 21:02:59 +08:00
import (
2022-05-20 00:02:30 +08:00
"gitee.com/golang-module/carbon"
2021-09-15 21:02:59 +08:00
)
```
2022-05-20 00:02:30 +08:00
> v1 和 v2 版本区别请查阅 <a href="#常见问题">常见问题</a>
#### 用法示例
2021-08-16 09:34:15 +08:00
> 默认时区为 Local即服务器所在时区假设当前时间为 2020-08-05 13:14:15
2020-10-07 17:15:46 +08:00
##### 昨天、今天、明天
2021-08-16 09:34:15 +08:00
2020-10-07 17:15:46 +08:00
```go
// 今天此刻
2021-07-19 09:55:54 +08:00
fmt.Sprintf("%s", carbon.Now()) // 2020-08-05 13:14:15
carbon.Now().ToString() // 2020-08-05 13:14:15 +0800 CST
2020-10-07 17:15:46 +08:00
carbon.Now().ToDateTimeString() // 2020-08-05 13:14:15
// 今天日期
2020-10-07 17:15:46 +08:00
carbon.Now().ToDateString() // 2020-08-05
// 今天时间
2020-10-07 17:15:46 +08:00
carbon.Now().ToTimeString() // 13:14:15
2021-08-16 09:34:15 +08:00
// 指定时区的今天此刻
carbon.Now(Carbon.NewYork).ToDateTimeString() // 2020-08-05 14:14:15
// 今天秒级时间戳
2021-08-16 09:34:15 +08:00
carbon.Now().Timestamp() // 1596604455
// 今天毫秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Now().TimestampMilli() // 1596604455000
// 今天微秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Now().TimestampMicro() // 1596604455000000
// 今天纳秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Now().TimestampNano() // 1596604455000000000
2020-10-07 17:15:46 +08:00
// 昨天此刻
2021-07-19 09:55:54 +08:00
fmt.Sprintf("%s", carbon.Yesterday()) // 2020-08-04 13:14:15
carbon.Yesterday().ToString() // 2020-08-04 13:14:15 +0800 CST
2020-10-07 17:15:46 +08:00
carbon.Yesterday().ToDateTimeString() // 2020-08-04 13:14:15
// 昨天日期
2020-10-07 17:15:46 +08:00
carbon.Yesterday().ToDateString() // 2020-08-04
// 昨天时间
2020-10-10 16:11:22 +08:00
carbon.Yesterday().ToTimeString() // 13:14:15
// 指定日期的昨天此刻
carbon.Parse("2021-01-28 13:14:15").Yesterday().ToDateTimeString() // 2021-01-27 13:14:15
// 指定时区的昨天此刻
2021-07-23 11:05:33 +08:00
carbon.Yesterday(Carbon.NewYork).ToDateTimeString() // 2020-08-04 14:14:15
2021-08-16 09:34:15 +08:00
// 昨天秒级时间戳
carbon.Yesterday().Timestamp() // 1596518055
// 昨天毫秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Yesterday().TimestampMilli() // 1596518055000
2021-08-16 09:34:15 +08:00
// 昨天微秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Yesterday().TimestampMicro() // 1596518055000000
2021-08-16 09:34:15 +08:00
// 昨天纳秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Yesterday().TimestampNano() // 1596518055000000000
2020-10-07 17:15:46 +08:00
// 明天此刻
2021-07-19 09:55:54 +08:00
fmt.Sprintf("%s", carbon.Tomorrow()) // 2020-08-06 13:14:15
carbon.Tomorrow().ToString() // 2020-08-06 13:14:15 +0800 CST
2020-10-07 17:15:46 +08:00
carbon.Tomorrow().ToDateTimeString() // 2020-08-06 13:14:15
// 明天日期
2020-10-07 17:15:46 +08:00
carbon.Tomorrow().ToDateString() // 2020-08-06
// 明天时间
2020-10-10 16:11:22 +08:00
carbon.Tomorrow().ToTimeString() // 13:14:15
// 指定日期的明天此刻
carbon.Parse("2021-01-28 13:14:15").Tomorrow().ToDateTimeString() // 2021-01-29 13:14:15
// 指定时区的明天此刻
2021-07-23 11:05:33 +08:00
carbon.Tomorrow(Carbon.NewYork).ToDateTimeString() // 2020-08-06 14:14:15
2021-08-16 09:34:15 +08:00
// 明天秒级时间戳
carbon.Tomorrow().Timestamp() // 1596690855
// 明天毫秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Tomorrow().TimestampMilli() // 1596690855000
2021-08-16 09:34:15 +08:00
// 明天微秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Tomorrow().TimestampMicro() // 1596690855000000
2021-08-16 09:34:15 +08:00
// 明天纳秒级时间戳
2022-04-12 17:40:58 +08:00
carbon.Tomorrow().TimestampNano() // 1596690855000000000
2020-10-07 17:15:46 +08:00
```
2021-07-31 13:08:43 +08:00
##### 创建 Carbon 实例
2021-08-16 09:34:15 +08:00
2020-10-07 17:15:46 +08:00
```go
2021-07-31 13:08:43 +08:00
// 从秒级时间戳创建 Carbon 实例
2022-04-12 17:40:58 +08:00
carbon.CreateFromTimestamp(-1).ToString() // 1970-01-01 07:59:59 +0800 CST
carbon.CreateFromTimestamp(0).ToString() // 1970-01-01 08:00:00 +0800 CST
carbon.CreateFromTimestamp(1).ToString() // 1970-01-01 08:00:01 +0800 CST
carbon.CreateFromTimestamp(1649735755).ToString() // 2022-04-12 11:55:55 +0800 CST
2021-07-31 13:08:43 +08:00
// 从毫秒级时间戳创建 Carbon 实例
2022-04-12 17:40:58 +08:00
carbon.CreateFromTimestampMilli(1649735755981).ToString() // 2022-04-12 11:55:55.981 +0800 CST
2021-07-31 13:08:43 +08:00
// 从微秒级时间戳创建 Carbon 实例
2022-04-12 17:40:58 +08:00
carbon.CreateFromTimestampMicro(1649735755981566).ToString() // 2022-04-12 11:55:55.981566 +0800 CST
2022-04-12 23:24:23 +08:00
// 从纳秒级时间戳创建 Carbon 实例
2022-04-12 17:40:58 +08:00
carbon.CreateFromTimestampNano(1649735755981566000).ToString() // 2022-04-12 11:55:55.981566 +0800 CST
2020-11-02 10:35:18 +08:00
2021-07-31 13:08:43 +08:00
// 从年月日时分秒创建 Carbon 实例
2022-05-04 23:55:39 +08:00
carbon.CreateFromDateTime(2020, 8, 5, 13, 14, 15).ToString() // 2020-08-05 13:14:15 +0800 CST
2022-04-12 23:24:23 +08:00
// 从年月日时分秒创建 Carbon 实例,包含毫秒
2022-05-04 23:55:39 +08:00
carbon.CreateFromDateTimeMilli(2020, 8, 5, 13, 14, 15, 999).ToString() // 2020-08-05 13:14:15.999 +0800 CST
2022-04-12 23:24:23 +08:00
// 从年月日时分秒创建 Carbon 实例,包含微秒
2022-05-04 23:55:39 +08:00
carbon.CreateFromDateTimeMicro(2020, 8, 5, 13, 14, 15, 999999).ToString() // 2020-08-05 13:14:15.999999 +0800 CST
2022-04-12 23:24:23 +08:00
// 从年月日时分秒创建 Carbon 实例,包含纳秒
2022-05-04 23:55:39 +08:00
carbon.CreateFromDateTimeNano(2020, 8, 5, 13, 14, 15, 999999999).ToString() // 2020-08-05 13:14:15.999999999 +0800 CST
2022-04-12 23:24:23 +08:00
2021-07-31 13:08:43 +08:00
// 从年月日创建 Carbon 实例(时分秒默认为当前时分秒)
2022-05-04 23:55:39 +08:00
carbon.CreateFromDate(2020, 8, 5).ToString() // // 2020-08-05 13:14:15 +0800 CST
// 从年月日创建 Carbon 实例(时分秒默认为当前时分秒),包含毫秒
carbon.CreateFromDateMilli(2020, 8, 5, 999).ToString() // 2020-08-05 13:14:15.999 +0800 CST
// 从年月日创建 Carbon 实例(时分秒默认为当前时分秒),包含微秒
carbon.CreateFromDateMicro(2020, 8, 5, 999999).ToString() // 2020-08-05 13:14:15.999999 +0800 CST
// 从年月日创建 Carbon 实例(时分秒默认为当前时分秒),包含纳秒
carbon.CreateFromDateNano(2020, 8, 5, 999999999).ToString() // 2020-08-05 13:14:15.999999999 +0800 CST
2021-07-31 13:08:43 +08:00
// 从时分秒创建 Carbon 实例(年月日默认为当前年月日)
2022-05-04 23:55:39 +08:00
carbon.CreateFromTime(13, 14, 15).ToString() // 2020-08-05 13:14:15 +0800 CST
// 从时分秒创建 Carbon 实例(年月日默认为当前年月日),包含毫秒
carbon.CreateFromTimeMilli(13, 14, 15, 999).ToString() // 2020-08-05 13:14:15.999 +0800 CST
// 从时分秒创建 Carbon 实例(年月日默认为当前年月日),包含微秒
carbon.CreateFromTimeMicro(13, 14, 15, 999999).ToString() // 2020-08-05 13:14:15.999999 +0800 CST
// 从时分秒创建 Carbon 实例(年月日默认为当前年月日),包含纳秒
carbon.CreateFromTimeNano(13, 14, 15, 999999999).ToString() // 2020-08-05 13:14:15.999999999 +0800 CST
```
2021-07-31 13:08:43 +08:00
##### 将标准格式时间字符串解析成 Carbon 实例
2021-08-16 09:34:15 +08:00
2020-10-07 17:15:46 +08:00
```go
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() // 空字符串
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05").ToString() // 2020-08-05 00:00:00 +0800 CST
carbon.Parse("2020-08-05 13:14:15").ToString() // 2020-08-05 13:14:15 +0800 CST
carbon.Parse("2020-08-05 13:14:15.999").ToString() // 2020-08-05 13:14:15.999 +0800 CST
carbon.Parse("2020-08-05 13:14:15.999999").ToString() // 2020-08-05 13:14:15.999999 +0800 CST
carbon.Parse("2020-08-05 13:14:15.999999999").ToString() // 2020-08-05 13:14:15.999999999 +0800 CST
carbon.Parse("2020-08-05T13:14:15+08:00").ToString() // 2020-08-05 13:14:15 +0800 CST
2022-04-12 17:40:58 +08:00
carbon.Parse("2020-08-05T13:14:15.999+08:00").ToString() // 2020-08-05 13:14:15.999 +0800 CST
carbon.Parse("2020-08-05T13:14:15.999999+08:00").ToString() // 2020-08-05 13:14:15.999999 +0800 CST
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToString() // 2020-08-05 13:14:15.999999999 +0800 CST
2022-04-18 11:05:17 +08:00
carbon.Parse("20200805").ToString() // 2020-08-05 00:00:00 +0800 CST
carbon.Parse("20200805131415").ToString() // 2020-08-05 13:14:15 +0800 CST
carbon.Parse("20200805131415.999").ToString() // 2020-08-05 13:14:15.999 +0800 CST
carbon.Parse("20200805131415.999999").ToString() // 2020-08-05 13:14:15.999999 +0800 CST
carbon.Parse("20200805131415.999999999").ToString() // 2020-08-05 13:14:15.999999999 +0800 CST
2020-10-07 17:15:46 +08:00
```
##### 通过格式模板将字符串解析成 Carbon 实例
2021-08-16 09:34:15 +08:00
2022-05-04 10:18:29 +08:00
> 如果使用的字母与格式模板冲突时,请使用转义符转义该字母
2021-08-16 09:34:15 +08:00
2020-10-07 17:15:46 +08:00
```go
2021-04-27 16:01:19 +08:00
carbon.ParseByFormat("2020|08|05 13|14|15", "Y|m|d H|i|s").ToDateTimeString() // 2020-08-05 13:14:15
2021-07-19 09:55:54 +08:00
carbon.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:15
2021-04-27 16:01:19 +08:00
carbon.ParseByFormat("今天是 2020年08月05日13时14分15秒", "今天是 Y年m月d日H时i分s秒").ToDateTimeString() // 2020-08-05 13:14:15
2021-07-23 11:05:33 +08:00
carbon.ParseByFormat("2020-08-05 13:14:15", "Y-m-d H:i:s", carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15
```
##### 通过布局模板将字符串解析成 Carbon 实例
2021-08-16 09:34:15 +08:00
```go
2021-06-29 18:19:39 +08:00
carbon.ParseByLayout("2020|08|05 13|14|15", "2006|01|02 15|04|05").ToDateTimeString() // 2020-08-05 13:14:15
carbon.ParseByLayout("It is 2020-08-05 13:14:15", "It is 2006-01-02 15:04:05").ToDateTimeString() // 2020-08-05 13:14:15
carbon.ParseByLayout("今天是 2020年08月05日13时14分15秒", "今天是 2006年01月02日15时04分05秒").ToDateTimeString() // 2020-08-05 13:14:15
2021-07-23 11:05:33 +08:00
carbon.ParseByLayout("2020-08-05 13:14:15", "2006-01-02 15:04:05", carbon.Tokyo).ToDateTimeString() // 2020-08-05 14:14:15
```
2021-07-31 13:08:43 +08:00
##### Carbon 和 time.Time 互转
2021-08-16 09:34:15 +08:00
```go
2021-07-31 13:08:43 +08:00
// 将 time.Time 转换成 Carbon
carbon.Time2Carbon(time.Now())
// 将 Carbon 转换成 time.Time
2021-06-29 18:19:39 +08:00
carbon.Now().Carbon2Time()
2020-10-07 17:15:46 +08:00
```
##### 开始时间、结束时间
2021-08-16 09:34:15 +08:00
2020-10-22 09:34:10 +08:00
```go
// 本世纪开始时间
2021-06-29 18:19:39 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfCentury().ToDateTimeString() // 2000-01-01 00:00:00
// 本世纪结束时间
2021-06-29 18:19:39 +08: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:00
carbon.Parse("2021-08-05 13:14:15").StartOfDecade().ToDateTimeString() // 2020-01-01 00:00:00
carbon.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:59
carbon.Parse("2021-08-05 13:14:15").EndOfDecade().ToDateTimeString() // 2029-12-31 23:59:59
carbon.Parse("2029-08-05 13:14:15").EndOfDecade().ToDateTimeString() // 2029-12-31 23:59:59
// 本年开始时间
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfYear().ToDateTimeString() // 2020-01-01 00:00:00
// 本年结束时间
2020-11-02 22:44:35 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfYear().ToDateTimeString() // 2020-12-31 23:59:59
2020-10-07 17:15:46 +08:00
// 本季度开始时间
2021-06-29 18:19:39 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfQuarter().ToDateTimeString() // 2020-07-01 00:00:00
// 本季度结束时间
2021-06-29 18:19:39 +08: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
// 本月结束时间
2020-11-02 22:44:35 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfMonth().ToDateTimeString() // 2020-08-31 23:59:59
2020-10-22 09:34:10 +08:00
// 本周开始时间
2021-08-16 09:34:15 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfWeek().ToDateTimeString() // 2020-08-02 00:00:00
carbon.Parse("2020-08-05 13:14:15").SetWeekStartsAt(carbon.Sunday).StartOfWeek().ToDateTimeString() // 2020-08-02 00:00:00
carbon.Parse("2020-08-05 13:14:15").SetWeekStartsAt(carbon.Monday).StartOfWeek().ToDateTimeString() // 2020-08-03 00:00:00
// 本周结束时间
2021-08-16 09:34:15 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfWeek().ToDateTimeString() // 2020-08-08 23:59:59
carbon.Parse("2020-08-05 13:14:15").SetWeekStartsAt(carbon.Sunday).EndOfWeek().ToDateTimeString() // 2020-08-08 23:59:59
carbon.Parse("2020-08-05 13:14:15").SetWeekStartsAt(carbon.Monday).EndOfWeek().ToDateTimeString() // 2020-08-09 23:59:59
2020-10-22 09:34:10 +08:00
// 本日开始时间
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfDay().ToDateTimeString() // 2020-08-05 00:00:00
// 本日结束时间
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfDay().ToDateTimeString() // 2020-08-05 23:59:59
// 本小时开始时间
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfHour().ToDateTimeString() // 2020-08-05 13:00:00
// 本小时结束时间
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfHour().ToDateTimeString() // 2020-08-05 13:59:59
// 本分钟开始时间
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfMinute().ToDateTimeString() // 2020-08-05 13:14:00
// 本分钟结束时间
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfMinute().ToDateTimeString() // 2020-08-05 13:14:59
2021-02-18 14:32:31 +08:00
// 本秒开始时间
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfSecond().ToString() // 2020-08-05 13:14:15 +0800 CST
// 本秒结束时间
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfSecond().ToString() // 2020-08-05 13:14:15.999999999 +0800 CST
2020-10-07 17:15:46 +08:00
```
##### 时间旅行
2021-08-16 09:34:15 +08:00
2020-10-07 17:15:46 +08:00
```go
2021-08-05 19:36:51 +08:00
// 三个世纪后
carbon.Parse("2020-02-29 13:14:15").AddCenturies(3).ToDateTimeString() // 2320-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 三个世纪后(月份不溢出)
carbon.Parse("2020-02-29 13:14:15").AddCenturiesNoOverflow(3).ToDateTimeString() // 2320-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 一个世纪后
carbon.Parse("2020-02-29 13:14:15").AddCentury().ToDateTimeString() // 2120-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 一个世纪后(月份不溢出)
carbon.Parse("2020-02-29 13:14:15").AddCenturyNoOverflow().ToDateTimeString() // 2120-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 三个世纪前
carbon.Parse("2020-02-29 13:14:15").SubCenturies(3).ToDateTimeString() // 1720-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 三个世纪前(月份不溢出)
carbon.Parse("2020-02-29 13:14:15").SubCenturiesNoOverflow(3).ToDateTimeString() // 1720-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 一个世纪前
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
2021-08-05 19:36:51 +08:00
// 三个年代后
2022-04-14 11:32:46 +08:00
carbon.Parse("2020-02-29 13:14:15").AddDecades(3).ToDateTimeString() // 2050-03-01 13:14:15
2021-08-05 19:36:51 +08:00
// 三个年代后(月份不溢出)
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
// 三年后
2020-10-07 17:15:46 +08:00
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
// 一年后
2020-10-07 17:15:46 +08:00
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
// 三年前
2020-10-07 17:15:46 +08:00
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
// 一年前
2020-10-07 17:15:46 +08:00
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
2020-10-07 17:15:46 +08:00
2021-08-05 19:36:51 +08:00
// 三个季度后
2020-11-02 10:35:18 +08:00
carbon.Parse("2019-08-31 13:14:15").AddQuarters(3).ToDateTimeString() // 2019-03-02 13:14:15
2021-08-05 19:36:51 +08:00
// 三个季度后(月份不溢出)
carbon.Parse("2019-08-31 13:14:15").AddQuartersNoOverflow(3).ToDateTimeString() // 2019-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 一个季度后
2020-11-02 10:35:18 +08:00
carbon.Parse("2019-11-30 13:14:15").AddQuarter().ToDateTimeString() // 2020-03-01 13:14:15
2021-08-05 19:36:51 +08:00
// 一个季度后(月份不溢出)
carbon.Parse("2019-11-30 13:14:15").AddQuarterNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 三个季度前
2020-11-02 10:35:18 +08:00
carbon.Parse("2019-08-31 13:14:15").SubQuarters(3).ToDateTimeString() // 2019-03-03 13:14:15
2021-08-05 19:36:51 +08:00
// 三个季度前(月份不溢出)
carbon.Parse("2019-08-31 13:14:15").SubQuartersNoOverflow(3).ToDateTimeString() // 2019-02-28 13:14:15
2021-08-05 19:36:51 +08:00
// 一个季度前
2020-11-02 10:35:18 +08:00
carbon.Parse("2020-05-31 13:14:15").SubQuarter().ToDateTimeString() // 2020-03-02 13:14:15
2021-08-05 19:36:51 +08:00
// 一个季度前(月份不溢出)
carbon.Parse("2020-05-31 13:14:15").SubQuarterNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15
2020-11-02 10:35:18 +08:00
2021-08-05 19:36:51 +08:00
// 三个月后
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-02-29 13:14:15").AddMonths(3).ToDateTimeString() // 2020-05-29 13:14:15
2021-08-05 19:36:51 +08:00
// 三个月后(月份不溢出)
carbon.Parse("2020-02-29 13:14:15").AddMonthsNoOverflow(3).ToDateTimeString() // 2020-05-29 13:14:15
2021-08-05 19:36:51 +08:00
// 一个月后
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-01-31 13:14:15").AddMonth().ToDateTimeString() // 2020-03-02 13:14:15
2021-08-05 19:36:51 +08:00
// 一个月后(月份不溢出)
carbon.Parse("2020-01-31 13:14:15").AddMonthNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15
2021-08-05 19:36:51 +08:00
// 三个月前
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-02-29 13:14:15").SubMonths(3).ToDateTimeString() // 2019-11-29 13:14:15
2021-08-05 19:36:51 +08:00
// 三个月前(月份不溢出)
carbon.Parse("2020-02-29 13:14:15").SubMonthsNoOverflow(3).ToDateTimeString() // 2019-11-29 13:14:15
2021-08-05 19:36:51 +08:00
// 一个月前
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-03-31 13:14:15").SubMonth().ToDateTimeString() // 2020-03-02 13:14:15
2021-08-05 19:36:51 +08:00
// 一个月前(月份不溢出)
carbon.Parse("2020-03-31 13:14:15").SubMonthNoOverflow().ToDateTimeString() // 2020-02-29 13:14:15
2020-10-07 17:15:46 +08:00
// 三周后
2020-11-02 10:35:18 +08:00
carbon.Parse("2020-02-29 13:14:15").AddWeeks(3).ToDateTimeString() // 2020-03-21 13:14:15
// 一周后
2020-11-02 10:35:18 +08:00
carbon.Parse("2020-02-29 13:14:15").AddWeek().ToDateTimeString() // 2020-03-07 13:14:15
// 三周前
2020-11-02 10:35:18 +08:00
carbon.Parse("2020-02-29 13:14:15").SubWeeks(3).ToDateTimeString() // 2020-02-08 13:14:15
// 一周前
2020-11-02 10:35:18 +08:00
carbon.Parse("2020-02-29 13:14:15").SubWeek().ToDateTimeString() // 2020-02-22 13:14:15
// 三天后
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").AddDays(3).ToDateTimeString() // 2020-08-08 13:14:15
// 一天后
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").AddDay().ToDateTimeString() // 2020-08-05 13:14:15
// 三天前
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").SubDays(3).ToDateTimeString() // 2020-08-02 13:14:15
// 一天前
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").SubDay().ToDateTimeString() // 2020-08-04 13:14:15
// 三小时后
2020-10-07 17:15:46 +08:00
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:15
carbon.Parse("2020-08-05 13:14:15").AddDuration("2h30m").ToDateTimeString() // 2020-08-05 15:44:15
// 一小时后
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").AddHour().ToDateTimeString() // 2020-08-05 14:14:15
// 三小时前
2020-10-07 17:15:46 +08:00
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:15
carbon.Parse("2020-08-05 13:14:15").SubDuration("2h30m").ToDateTimeString() // 2020-08-05 10:44:15
// 一小时前
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").SubHour().ToDateTimeString() // 2020-08-05 12:14:15
// 三分钟后
2020-10-07 17:15:46 +08:00
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:45
carbon.Parse("2020-08-05 13:14:15").AddDuration("2m30s").ToDateTimeString() // 2020-08-05 13:16:45
// 一分钟后
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").AddMinute().ToDateTimeString() // 2020-08-05 13:15:15
// 三分钟前
2020-10-07 17:15:46 +08:00
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:45
carbon.Parse("2020-08-05 13:14:15").SubDuration("2m30s").ToDateTimeString() // 2020-08-05 13:11:45
// 一分钟前
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").SubMinute().ToDateTimeString() // 2020-08-05 13:13:15
// 三秒钟后
2020-10-07 17:15:46 +08:00
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
// 一秒钟后
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").AddSecond().ToDateTimeString() // 2020-08-05 13:14:16
// 三秒钟前
2020-10-07 17:15:46 +08:00
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
// 一秒钟前
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").SubSecond().ToDateTimeString() // 2020-08-05 13:14:14
// 三毫秒后
carbon.Parse("2020-08-05 13:14:15.222222222").AddMilliseconds(3).ToString() // 2020-08-05 13:14:15.225222222 +0800 CST
// 一毫秒后
carbon.Parse("2020-08-05 13:14:15.222222222").AddMillisecond().ToString() // 2020-08-05 13:14:15.223222222 +0800 CST
// 三毫秒前
carbon.Parse("2020-08-05 13:14:15.222222222").SubMilliseconds(3).ToString() // 2020-08-05 13:14:15.219222222 +0800 CST
// 一毫秒前
carbon.Parse("2020-08-05 13:14:15.222222222").SubMillisecond().ToString() // 2020-08-05 13:14:15.221222222 +0800 CST
// 三微秒后
carbon.Parse("2020-08-05 13:14:15.222222222").AddMicroseconds(3).ToString() // 2020-08-05 13:14:15.222225222 +0800 CST
// 一微秒后
carbon.Parse("2020-08-05 13:14:15.222222222").AddMicrosecond().ToString() // 2020-08-05 13:14:15.222223222 +0800 CST
// 三微秒前
carbon.Parse("2020-08-05 13:14:15.222222222").SubMicroseconds(3).ToString() // 2020-08-05 13:14:15.222219222 +0800 CST
// 一微秒前
carbon.Parse("2020-08-05 13:14:15.222222222").SubMicrosecond().ToString() // 2020-08-05 13:14:15.222221222 +0800 CST
// 三纳秒后
carbon.Parse("2020-08-05 13:14:15.222222222").AddNanoseconds(3).ToString() // 2020-08-05 13:14:15.222222225 +0800 CST
// 一纳秒后
carbon.Parse("2020-08-05 13:14:15.222222222").AddNanossecond().ToString() // 2020-08-05 13:14:15.222222223 +0800 CST
// 三纳秒前
carbon.Parse("2020-08-05 13:14:15.222222222").SubNanosseconds(3).ToString() // 2020-08-05 13:14:15.222222219 +0800 CST
// 一纳秒前
carbon.Parse("2020-08-05 13:14:15.222222222").SubNanossecond().ToString() // 2020-08-05 13:14:15.222222221 +0800 CST
2020-10-22 09:34:10 +08:00
```
2020-10-07 17:15:46 +08:00
##### 时间差
2021-08-16 09:34:15 +08:00
2020-10-22 09:34:10 +08:00
```go
2021-08-06 00:16:08 +08:00
// 相差多少年
carbon.Parse("2021-08-05 13:14:15").DiffInYears(carbon.Parse("2020-08-05 13:14:15")) // -1
// 相差多少年(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Parse("2021-08-05 13:14:15").DiffAbsInYears(carbon.Parse("2020-08-05 13:14:15")) // 1
2021-08-06 00:16:08 +08:00
// 相差多少月
carbon.Parse("2020-08-05 13:14:15").DiffInMonths(carbon.Parse("2020-07-05 13:14:15")) // -1
// 相差多少月(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffAbsInMonths(carbon.Parse("2020-07-05 13:14:15")) // 1
2021-08-06 00:16:08 +08:00
// 相差多少周
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffInWeeks(carbon.Parse("2020-07-28 13:14:15")) // -1
// 相差多少周(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffAbsInWeeks(carbon.Parse("2020-07-28 13:14:15")) // 1
2020-10-22 09:34:10 +08:00
// 相差多少天
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffInDays(carbon.Parse("2020-08-04 13:14:15")) // -1
// 相差多少天(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffAbsInDays(carbon.Parse("2020-08-04 13:14:15")) // 1
2020-10-22 09:34:10 +08:00
// 相差多少小时
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffInHours(carbon.Parse("2020-08-05 12:14:15")) // -1
// 相差多少小时(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffAbsInHours(carbon.Parse("2020-08-05 12:14:15")) // 1
2020-10-22 09:34:10 +08:00
// 相差多少分
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffInMinutes(carbon.Parse("2020-08-05 13:13:15")) // -1
// 相差多少分(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffAbsInMinutes(carbon.Parse("2020-08-05 13:13:15")) // 1
2020-10-22 09:34:10 +08:00
// 相差多少秒
2020-10-22 09:34:10 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffInSeconds(carbon.Parse("2020-08-05 13:14:14")) // -1
// 相差多少秒(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffAbsInSeconds(carbon.Parse("2020-08-05 13:14:14")) // 1
2021-09-10 20:44:55 +08:00
// 相差字符串
carbon.Now().DiffInString() // just now
carbon.Now().AddYearsNoOverflow(1).DiffInString() // -1 year
carbon.Now().SubYearsNoOverflow(1).DiffInString() // 1 year
// 相差字符串(绝对值)
2022-04-18 11:05:17 +08:00
carbon.Now().DiffAbsInString(carbon.Now()) // just now
carbon.Now().AddYearsNoOverflow(1).DiffAbsInString(carbon.Now()) // 1 year
carbon.Now().SubYearsNoOverflow(1).DiffAbsInString(carbon.Now()) // 1 year
2021-09-10 20:44:55 +08:00
2021-08-05 19:36:51 +08:00
// 对人类友好的可读格式时间差
2021-08-16 10:36:41 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffForHumans() // just now
2021-02-18 14:32:31 +08:00
carbon.Parse("2019-08-05 13:14:15").DiffForHumans() // 1 year ago
carbon.Parse("2018-08-05 13:14:15").DiffForHumans() // 2 years ago
carbon.Parse("2021-08-05 13:14:15").DiffForHumans() // 1 year from now
carbon.Parse("2022-08-05 13:14:15").DiffForHumans() // 2 years from now
2021-02-18 14:32:31 +08:00
carbon.Parse("2020-08-05 13:14:15").DiffForHumans(carbon.Now()) // 1 year before
carbon.Parse("2019-08-05 13:14:15").DiffForHumans(carbon.Now()) // 2 years before
carbon.Parse("2018-08-05 13:14:15").DiffForHumans(carbon.Now()) // 1 year after
carbon.Parse("2022-08-05 13:14:15").DiffForHumans(carbon.Now()) // 2 years after
2020-11-06 09:28:10 +08:00
```
##### 时间判断
2021-08-16 09:34:15 +08:00
2020-11-06 09:28:10 +08:00
```go
// 是否是零值时间
2020-11-06 09:28:10 +08:00
carbon.Parse("").IsZero() // true
carbon.Parse("0").IsZero() // true
carbon.Parse("0000-00-00 00:00:00").IsZero() // true
carbon.Parse("0000-00-00").IsZero() // true
carbon.Parse("00:00:00").IsZero() // true
carbon.Parse("2020-08-05 00:00:00").IsZero() // false
carbon.Parse("2020-08-05").IsZero() // false
2021-07-23 11:05:33 +08:00
carbon.Parse("2020-08-05").SetTimezone("xxx").IsZero() // false
2022-04-21 15:08:24 +08:00
// 是否是有效时间
carbon.Parse("").IsValid() // false
carbon.Parse("0").IsValid() // false
carbon.Parse("0000-00-00 00:00:00").IsValid() // false
carbon.Parse("0000-00-00").IsValid() // false
carbon.Parse("00:00:00").IsValid() // false
carbon.Parse("2020-08-05 00:00:00").IsValid() // true
carbon.Parse("2020-08-05").IsValid() // true
carbon.Parse("2020-08-05").SetTimezone("xxx").IsValid() // false
// 是否是无效时间
2021-07-23 11:05:33 +08:00
carbon.Parse("").IsInvalid() // true
carbon.Parse("0").IsInvalid() // true
carbon.Parse("0000-00-00 00:00:00").IsInvalid() // true
carbon.Parse("0000-00-00").IsInvalid() // true
carbon.Parse("00:00:00").IsInvalid() // true
carbon.Parse("2020-08-05 00:00:00").IsInvalid() // false
carbon.Parse("2020-08-05").IsInvalid() // false
carbon.Parse("2020-08-05").SetTimezone("xxx").IsInvalid() // true
// 是否是当前时间
2020-11-06 09:28:10 +08:00
carbon.Now().IsNow() // true
// 是否是未来时间
2020-11-06 09:28:10 +08:00
carbon.Tomorrow().IsFuture() // true
// 是否是过去时间
2020-11-06 09:28:10 +08:00
carbon.Yesterday().IsPast() // true
// 是否是闰年
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsLeapYear() // true
// 是否是长年
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsLongYear() // true
// 是否是一月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsJanuary() // false
// 是否是二月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsFebruary() // false
// 是否是三月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsMarch() // false
// 是否是四月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsApril() // false
// 是否是五月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsMay() // false
// 是否是六月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsJune() // false
// 是否是七月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsJuly() // false
// 是否是八月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsAugust() // false
// 是否是九月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsSeptember() // true
// 是否是十月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsOctober() // false
// 是否是十一月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsNovember() // false
// 是否是十二月
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsDecember() // false
// 是否是周一
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsMonday() // false
// 是否是周二
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsTuesday() // true
// 是否是周三
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsWednesday() // false
// 是否是周四
2021-08-16 09:34:15 +08:00
carbon.Parse("2020-08-05 13:14:15").IsThursday() // false
// 是否是周五
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsFriday() // false
// 是否是周六
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsSaturday() // false
// 是否是周日
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsSunday() // false
// 是否是工作日
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsWeekday() // false
// 是否是周末
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsWeekend() // true
// 是否是昨天
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-04 13:14:15").IsYesterday() // true
carbon.Parse("2020-08-04 00:00:00").IsYesterday() // true
carbon.Parse("2020-08-04").IsYesterday() // true
// 是否是今天
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-05 13:14:15").IsToday() // true
carbon.Parse("2020-08-05 00:00:00").IsToday() // true
carbon.Parse("2020-08-05").IsToday() // true
// 是否是明天
2020-11-06 09:28:10 +08:00
carbon.Parse("2020-08-06 13:14:15").IsTomorrow() // true
carbon.Parse("2020-08-06 00:00:00").IsTomorrow() // true
carbon.Parse("2020-08-06").IsTomorrow() // true
2021-02-18 14:32:31 +08:00
2022-05-20 00:02:30 +08:00
// 是否是同一世纪
carbon.Parse("2020-08-05 13:14:15").IsSameCentury(carbon.Parse("3020-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:14:15").IsSameCentury(carbon.Parse("2099-08-05 13:14:15")) // true
// 是否是同一年代
carbon.Parse("2020-08-05 13:14:15").IsSameDecade(carbon.Parse("2030-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:14:15").IsSameDecade(carbon.Parse("2120-08-05 13:14:15")) // true
// 是否是同一年
carbon.Parse("2020-08-05 00:00:00").IsSameYear(carbon.Parse("2021-08-05 13:14:15")) // false
carbon.Parse("2020-01-01 00:00:00").IsSameYear(carbon.Parse("2020-12-31 13:14:15")) // true
// 是否是同一季节
carbon.Parse("2020-08-05 00:00:00").IsSameQuarter(carbon.Parse("2020-09-05 13:14:15")) // false
carbon.Parse("2020-01-01 00:00:00").IsSameQuarter(carbon.Parse("2021-01-31 13:14:15")) // true
// 是否是同一月
carbon.Parse("2020-01-01 00:00:00").IsSameMonth(carbon.Parse("2021-01-31 13:14:15")) // false
carbon.Parse("2020-01-01 00:00:00").IsSameMonth(carbon.Parse("2020-01-31 13:14:15")) // true
// 是否是同一天
carbon.Parse("2020-08-05 13:14:15").IsSameDay(carbon.Parse("2021-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 00:00:00").IsSameDay(carbon.Parse("2020-08-05 13:14:15")) // true
// 是否是同一小时
carbon.Parse("2020-08-05 13:14:15").IsSameHour(carbon.Parse("2021-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:00:00").IsSameHour(carbon.Parse("2020-08-05 13:14:15")) // true
// 是否是同一分钟
carbon.Parse("2020-08-05 13:14:15").IsSameMinute(carbon.Parse("2021-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:14:00").IsSameMinute(carbon.Parse("2020-08-05 13:14:15")) // true
// 是否是同一秒
carbon.Parse("2020-08-05 13:14:15").IsSameSecond(carbon.Parse("2021-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:14:15").IsSameSecond(carbon.Parse("2020-08-05 13:14:15")) // true
// 是否大于
2021-02-18 14:32:31 +08:00
carbon.Parse("2020-08-05 13:14:15").Gt(carbon.Parse("2020-08-04 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Gt(carbon.Parse("2020-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:14:15").Compare(">", carbon.Parse("2020-08-04 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Compare(">", carbon.Parse("2020-08-05 13:14:15")) // false
// 是否小于
2021-02-18 14:32:31 +08:00
carbon.Parse("2020-08-05 13:14:15").Lt(carbon.Parse("2020-08-06 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Lt(carbon.Parse("2020-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:14:15").Compare("<", carbon.Parse("2020-08-06 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Compare("<", carbon.Parse("2020-08-05 13:14:15")) // false
// 是否等于
2021-02-18 14:32:31 +08:00
carbon.Parse("2020-08-05 13:14:15").Eq(carbon.Parse("2020-08-05 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Eq(carbon.Parse("2020-08-05 13:14:00")) // false
carbon.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").Compare("=", carbon.Parse("2020-08-05 13:14:00")) // false
// 是否不等于
2021-02-18 14:32:31 +08:00
carbon.Parse("2020-08-05 13:14:15").Ne(carbon.Parse("2020-08-06 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Ne(carbon.Parse("2020-08-05 13:14:15")) // false
carbon.Parse("2020-08-05 13:14:15").Compare("!=", carbon.Parse("2020-08-06 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Compare("<>", carbon.Parse("2020-08-05 13:14:15")) // false
// 是否大于等于
2021-02-18 14:32:31 +08:00
carbon.Parse("2020-08-05 13:14:15").Gte(carbon.Parse("2020-08-04 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Gte(carbon.Parse("2020-08-05 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Compare(">=", carbon.Parse("2020-08-04 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Compare(">=", carbon.Parse("2020-08-05 13:14:15")) // true
// 是否小于等于
2021-02-18 14:32:31 +08:00
carbon.Parse("2020-08-05 13:14:15").Lte(carbon.Parse("2020-08-06 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Lte(carbon.Parse("2020-08-05 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Compare("<=", carbon.Parse("2020-08-06 13:14:15")) // true
carbon.Parse("2020-08-05 13:14:15").Compare("<=", carbon.Parse("2020-08-05 13:14:15")) // true
// 是否在两个时间之间(不包括这两个时间)
2021-02-18 14:32:31 +08:00
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")) // false
carbon.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
// 是否在两个时间之间(包括开始时间)
2021-07-23 23:03:46 +08:00
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")) // true
carbon.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
2021-02-18 14:32:31 +08:00
// 是否在两个时间之间(包括结束时间)
2021-07-23 23:03:46 +08:00
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")) // true
carbon.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
2021-02-18 14:32:31 +08:00
// 是否在两个时间之间(包括这两个时间)
2021-02-18 14:32:31 +08:00
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")) // true
carbon.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
2020-10-07 17:15:46 +08:00
```
2021-08-16 09:34:15 +08:00
2021-07-24 12:57:30 +08:00
> 关于长年(LongYear)的定义, 请查看 https://en.wikipedia.org/wiki/ISO_8601#Week_dates
2020-10-07 17:15:46 +08:00
2021-08-09 16:47:20 +08:00
##### 时间设置
2021-08-16 09:34:15 +08:00
2021-08-09 16:47:20 +08:00
```go
// 设置时区
carbon.SetTimezone(carbon.PRC).Now().ToDateTimeString() // 2020-08-05 13:14:15
carbon.SetTimezone(carbon.Tokyo).Now().ToDateTimeString() // 2020-08-05 14:14:15
carbon.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 ago
carbon.Parse("2020-07-05 13:14:15").SetLocale("zh-CN").DiffForHumans() // 1 月前
2022-04-12 17:40:58 +08:00
// 设置年月日时分秒
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-01-01").SetDateTime(2019, 2, 2, 13, 14, 15).ToString() // 2019-02-02 13:14:15 +0800 CST
carbon.Parse("2020-01-01").SetDateTime(2019, 2, 31, 13, 14, 15).ToString() // 2019-03-03 13:14:15 +0800 CST
// 设置年月日时分秒毫秒
carbon.Parse("2020-01-01").SetDateTimeMilli(2019, 2, 2, 13, 14, 15, 999).ToString() // 2019-02-02 13:14:15.999 +0800 CST
carbon.Parse("2020-01-01").SetDateTimeMilli(2019, 2, 31, 13, 14, 15, 999).ToString() // 2019-03-03 13:14:15.999 +0800 CST
// 设置年月日时分秒微秒
carbon.Parse("2020-01-01").SetDateTimeMicro(2019, 2, 2, 13, 14, 15, 999999).ToString() // 2019-02-02 13:14:15.999999 +0800 CST
carbon.Parse("2020-01-01").SetDateTimeMicro(2019, 2, 31, 13, 14, 15, 999999).ToString() // 2019-03-03 13:14:15.999999 +0800 CST
// 设置年月日时分秒纳秒
carbon.Parse("2020-01-01").SetDateTimeNano(2019, 2, 2, 13, 14, 15, 999999999).ToString() // 2019-02-02 13:14:15.999999999 +0800 CST
carbon.Parse("2020-01-01").SetDateTimeNano(2019, 2, 31, 13, 14, 15, 999999999).ToString() // 2019-03-03 13:14:15.999999999 +0800 CST
2022-04-12 17:40:58 +08:00
// 设置年月日
2022-05-07 09:16:36 +08:00
carbon.Parse("2020-01-01").SetDate(2019, 2, 2).ToString() // 2019-02-02 00:00:00 +0800 CST
carbon.Parse("2020-01-01").SetDate(2019, 2, 31).ToString() // 2019-03-03 00:00:00 +0800 CST
// 设置年月日毫秒
carbon.Parse("2020-01-01").SetDateMilli(2019, 2, 2, 999).ToString() // 2019-02-02 00:00:00.999 +0800 CST
carbon.Parse("2020-01-01").SetDateMilli(2019, 2, 31, 999).ToString() // 2019-03-03 00:00:00.999 +0800 CST
// 设置年月日微秒
carbon.Parse("2020-01-01").SetDateMicro(2019, 2, 2, 999999).ToString() // 2019-02-02 00:00:00.999999 +0800 CST
carbon.Parse("2020-01-01").SetDateMicro(2019, 2, 31, 999999).ToString() // 2019-03-03 00:00:00.999999 +0800 CST
// 设置年月日纳秒
carbon.Parse("2020-01-01").SetDateNano(2019, 2, 2, 999999999).ToString() // 2019-02-02 00:00:00.999999999 +0800 CST
carbon.Parse("2020-01-01").SetDateNano(2019, 2, 31, 999999999).ToString() // 2019-03-03 00:00:00.999999999 +0800 CST
2022-04-12 17:40:58 +08:00
// 设置时分秒
2022-05-07 09:16:36 +08:00
carbon.Parse("2020-01-01").SetTime(13, 14, 15).ToString() // 2020-01-01 13:14:15 +0800 CST
carbon.Parse("2020-01-01").SetTime(13, 14, 90).ToString() // 2020-01-01 13:15:30 +0800 CST
// 设置时分秒毫秒
carbon.Parse("2020-01-01").SetTimeMilli(13, 14, 15, 999).ToString() // 2020-01-01 13:14:15.999 +0800 CST
carbon.Parse("2020-01-01").SetTimeMilli(13, 14, 90, 999).ToString() // 2020-01-01 13:15:30.999 +0800 CST
// 设置时分秒微秒
carbon.Parse("2020-01-01").SetTimeMicro(13, 14, 15, 999999).ToString() // 2020-01-01 13:14:15.999999 +0800 CST
carbon.Parse("2020-01-01").SetTimeMicro(13, 14, 90, 999999).ToString() // 2020-01-01 13:15:30.999999 +0800 CST
// 设置时分秒纳秒
carbon.Parse("2020-01-01").SetTimeNano(13, 14, 15, 999999999).ToString() // 2020-01-01 13:14:15.999999999 +0800 CST
carbon.Parse("2020-01-01").SetTimeNano(13, 14, 90, 999999999).ToString() // 2020-01-01 13:15:30.999999999 +0800 CST
2022-04-12 17:40:58 +08:00
2021-08-09 16:47:20 +08:00
// 设置年份
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
2021-08-16 09:34:15 +08:00
// 设置一周的开始日期
carbon.Parse("2020-08-02").SetWeekStartsAt(carbon.Monday).Week() // 6
carbon.Parse("2020-08-02").SetWeekStartsAt(carbon.Sunday).Week() // 0
2021-08-09 16:47:20 +08:00
// 设置日期
carbon.Parse("2019-08-05").SetDay(31).ToDateString() // 2020-08-31
carbon.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:15
carbon.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:15
carbon.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:10
carbon.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() // 100
carbon.Parse("2020-08-05 13:14:15").SetMillisecond(999).Millisecond() // 999
// 设置微妙
carbon.Parse("2020-08-05 13:14:15").SetMicrosecond(100000).Microsecond() // 100000
carbon.Parse("2020-08-05 13:14:15").SetMicrosecond(999999).Microsecond() // 999999
// 设置纳秒
carbon.Parse("2020-08-05 13:14:15").SetNanosecond(100000000).Nanosecond() // 100000000
carbon.Parse("2020-08-05 13:14:15").SetNanosecond(999999999).Nanosecond() // 999999999
```
##### 时间获取
2021-08-16 09:34:15 +08:00
2021-08-09 16:47:20 +08:00
```go
// 获取本年总天数
carbon.Parse("2019-08-05 13:14:15").DaysInYear() // 365
carbon.Parse("2020-08-05 13:14:15").DaysInYear() // 366
// 获取本月总天数
carbon.Parse("2020-02-01 13:14:15").DaysInMonth() // 29
carbon.Parse("2020-04-01 13:14:15").DaysInMonth() // 30
carbon.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() // 1
carbon.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() // 3
2022-04-12 17:40:58 +08:00
// 获取当前年月日时分秒
carbon.Parse("2020-08-05 13:14:15").DateTime() // 2020,8,5,13,14,15
2022-04-14 11:32:46 +08:00
// 获取当前年月日时分秒毫秒
carbon.Parse("2020-08-05 13:14:15").DateTimeMilli() // 2020,8,5,13,14,15,999
// 获取当前年月日时分秒微秒
carbon.Parse("2020-08-05 13:14:15").DateTimeMicro() // 2020,8,5,13,14,15,999999
// 获取当前年月日时分秒纳秒
carbon.Parse("2020-08-05 13:14:15").DateTimeNano() // 2020,8,5,13,14,15,999999999
2022-04-12 17:40:58 +08:00
// 获取当前年月日
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15.999999999").Date() // 2020,8,5
// 获取当前年月日毫秒
carbon.Parse("2020-08-05 13:14:15.999999999").DateMilli() // 2020,8,5,999
// 获取当前年月日微秒
carbon.Parse("2020-08-05 13:14:15.999999999").DateMicro() // 2020,8,5,999999
// 获取当前年月日纳秒
carbon.Parse("2020-08-05 13:14:15.999999999").DateNano() // 2020,8,5,999999999
2022-04-12 17:40:58 +08:00
// 获取当前时分秒
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15.999999999").Time() // 13,14,15
// 获取当前时分秒毫秒
carbon.Parse("2020-08-05 13:14:15.999999999").TimeMilli() // 13,14,15,999
// 获取当前时分秒微秒
carbon.Parse("2020-08-05 13:14:15.999999999").TimeMicro() // 13,14,15,999999
// 获取当前时分秒纳秒
carbon.Parse("2020-08-05 13:14:15.999999999").TimeNano() // 13,14,15,999999999
2022-04-12 17:40:58 +08:00
2021-08-09 16:47:20 +08:00
// 获取当前世纪
carbon.Parse("2020-08-05 13:14:15").Century() // 21
// 获取当前年代
carbon.Parse("2019-08-05 13:14:15").Decade() // 10
carbon.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开始)
2021-08-16 09:34:15 +08:00
carbon.Parse("2020-08-02 13:14:15").Week() // 0
carbon.Parse("2020-08-02").SetWeekStartsAt(carbon.Sunday).Week() // 0
carbon.Parse("2020-08-02").SetWeekStartsAt(carbon.Monday).Week() // 6
2021-08-09 16:47:20 +08:00
// 获取当前天数
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
// 获取当前毫秒
2022-04-12 17:40:58 +08:00
carbon.Parse("2020-08-05 13:14:15.999").Millisecond() // 999
2021-08-09 16:47:20 +08:00
// 获取当前微秒
2022-04-12 17:40:58 +08:00
carbon.Parse("2020-08-05 13:14:15.999").Microsecond() // 999000
2021-08-09 16:47:20 +08:00
// 获取当前纳秒
2022-04-12 17:40:58 +08:00
carbon.Parse("2020-08-05 13:14:15.999").Nanosecond() // 999000000
2021-08-09 16:47:20 +08:00
2022-04-12 23:24:23 +08:00
// 获取秒级时间戳
2021-08-16 09:34:15 +08:00
carbon.Parse("2020-08-05 13:14:15").Timestamp() // 1596604455
// 获取毫秒级时间戳
2022-04-12 23:24:23 +08:00
carbon.Parse("2020-08-05 13:14:15").TimestampMilli() // 1596604455000
2021-08-16 09:34:15 +08:00
// 获取微秒级时间戳
2022-04-12 23:24:23 +08:00
carbon.Parse("2020-08-05 13:14:15").TimestampMicro() // 1596604455000000
2021-08-16 09:34:15 +08:00
// 获取纳秒级时间戳
2022-04-12 23:24:23 +08:00
carbon.Parse("2020-08-05 13:14:15").TimestampNano() // 1596604455000000000
2021-08-16 09:34:15 +08:00
2021-08-09 16:47:20 +08:00
// 获取时区
carbon.SetTimezone(carbon.PRC).Timezone() // CST
carbon.SetTimezone(carbon.Tokyo).Timezone() // JST
// 获取位置
carbon.SetTimezone(carbon.PRC).Location() // PRC
carbon.SetTimezone(carbon.Tokyo).Location() // Asia/Tokyo
// 获取距离UTC时区的偏移量单位秒
carbon.SetTimezone(carbon.PRC).Offset() // 28800
carbon.SetTimezone(carbon.Tokyo).Offset() // 32400
// 获取当前区域
carbon.Now().Locale() // en
carbon.Now().SetLocale("zh-CN").Locale() // zh-CN
// 获取当前星座
carbon.Now().Constellation() // Leo
carbon.Now().SetLocale("en").Constellation() // Leo
carbon.Now().SetLocale("zh-CN").Constellation() // 狮子座
// 获取当前季节
carbon.Now().Season() // Summer
carbon.Now().SetLocale("en").Season() // Summer
carbon.Now().SetLocale("zh-CN").Season() // 夏季
// 获取年龄
carbon.Parse("2002-01-01 13:14:15").Age() // 17
carbon.Parse("2002-12-31 13:14:15").Age() // 18
```
##### 时间输出
2020-10-07 17:15:46 +08:00
2021-08-16 09:34:15 +08:00
```go
// 输出日期时间字符串
2022-04-12 17:40:58 +08:00
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToDateTimeString() // 2020-08-05 13:14:15
// 输出日期时间字符串,包含毫秒
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToDateTimeMilliString() // 2020-08-05 13:14:15.999
// 输出日期时间字符串,包含微秒
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToDateTimeMicroString() // 2020-08-05 13:14:15.999999
// 输出日期时间字符串,包含纳秒
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToDateTimeNanoString() // 2020-08-05 13:14:15.999999999
// 输出简写日期时间字符串
2022-04-12 17:40:58 +08:00
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToShortDateTimeString() // 20200805131415
// 输出简写日期时间字符串,包含毫秒
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToShortDateTimeMilliString() // 20200805131415.999
// 输出简写日期时间字符串,包含微秒
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToShortDateTimeMicroString() // 20200805131415.999999
// 输出简写日期时间字符串,包含纳秒
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToShortDateTimeNanoString() // 20200805131415.999999999
2021-07-23 11:05:33 +08:00
// 输出日期字符串
carbon.Parse("2020-08-05 13:14:15.999999999").ToDateString() // 2020-08-05
// 输出日期字符串,包含毫秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToDateMilliString() // 2020-08-05.999
// 输出日期字符串,包含微秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToDateMicroString() // 2020-08-05.999999
// 输出日期字符串,包含纳秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToDateNanoString() // 2020-08-05.999999999
// 输出简写日期字符串
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortDateString() // 20200805
// 输出简写日期字符串,包含毫秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortDateMilliString() // 20200805.999
// 输出简写日期字符串,包含微秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortDateMicroString() // 20200805.999999
// 输出简写日期字符串,包含纳秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortDateNanoString() // 20200805.999999999
2021-07-23 11:05:33 +08:00
// 输出时间字符串
carbon.Parse("2020-08-05 13:14:15.999999999").ToTimeString() // 13:14:15
// 输出时间字符串,包含毫秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToTimeMilliString() // 13:14:15.999
// 输出时间字符串,包含微秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToTimeMicroString() // 13:14:15.999999
// 输出时间字符串,包含纳秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToTimeNanoString() // 13:14:15.999999999
2020-10-07 17:15:46 +08:00
// 输出简写时间字符串
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortTimeString() // 131415
// 输出简写时间字符串,包含毫秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortTimeMilliString() // 131415.999
// 输出简写时间字符串,包含微秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortTimeMicroString() // 131415.999999
// 输出简写时间字符串,包含纳秒
carbon.Parse("2020-08-05 13:14:15.999999999").ToShortTimeNanoString() // 131415.999999999
// 输出 ANSIC 格式字符串
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15").ToANSICString() // Wed Aug 5 13:14:15 2020
// 输出 Atom 格式字符串
2021-06-04 16:17:52 +08:00
carbon.Parse("2020-08-05 13:14:15").ToAtomString() // 2020-08-05T13:14:15+08:00
// 输出 UnixDate 格式字符串
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").ToUnixDateString() // Wed Aug 5 13:14:15 CST 2020
// 输出 RubyDate 格式字符串
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").ToRubyDateString() // Wed Aug 05 13:14:15 +0800 2020
// 输出 Kitchen 格式字符串
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").ToKitchenString() // 1:14PM
// 输出 Cookie 格式字符串
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").ToCookieString() // Wednesday, 05-Aug-2020 13:14:15 CST
// 输出 DayDateTime 格式字符串
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").ToDayDateTimeString() // Wed, Aug 5, 2020 1:14 PM
// 输出 RSS 格式字符串
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").ToRssString() // Wed, 05 Aug 2020 13:14:15 +0800
// 输出 W3C 格式字符串
2020-10-07 17:15:46 +08:00
carbon.Parse("2020-08-05 13:14:15").ToW3cString() // 2020-08-05T13:14:15+08:00
// 输出 ISO8601 格式字符串
2022-04-18 11:05:17 +08:00
carbon.Parse("2020-08-05 13:14:15.999999999").ToIso8601String() // 2020-08-05T13:14:15+08:00
// 输出 ISO8601Milli 格式字符串
carbon.Parse("2020-08-05 13:14:15.999999999").ToIso8601MilliString() // 2020-08-05T13:14:15.999+08:00
// 输出 ISO8601Micro 格式字符串
carbon.Parse("2020-08-05 13:14:15.999999999").ToIso8601MicroString() // 2020-08-05T13:14:15.999999+08:00
// 输出 ISO8601Nano 格式字符串
carbon.Parse("2020-08-05 13:14:15.999999999").ToIso8601NanoString() // 2020-08-05T13:14:15.999999999+08:00
// 输出 RFC822 格式字符串
carbon.Parse("2020-08-05 13:14:15").ToRfc822String() // 05 Aug 20 13:14 CST
// 输出 RFC822Z 格式字符串
carbon.Parse("2020-08-05 13:14:15").ToRfc822zString() // 05 Aug 20 13:14 +0800
// 输出 RFC850 格式字符串
carbon.Parse("2020-08-05 13:14:15").ToRfc850String() // Wednesday, 05-Aug-20 13:14:15 CST
// 输出 RFC1036 格式字符串
carbon.Parse("2020-08-05 13:14:15").ToRfc1036String() // Wed, 05 Aug 20 13:14:15 +0800
// 输出 RFC1123 格式字符串
carbon.Parse("2020-08-05 13:14:15").ToRfc1123String() // Wed, 05 Aug 2020 13:14:15 CST
2021-07-28 09:18:51 +08:00
// 输出 RFC1123Z 格式字符串
carbon.Parse("2020-08-05 13:14:15").ToRfc1123zString() // Wed, 05 Aug 2020 13:14:15 +0800
// 输出 RFC2822 格式字符串
carbon.Parse("2020-08-05 13:14:15").ToRfc2822String() // Wed, 05 Aug 2020 13:14:15 +0800
// 输出 RFC7231 格式字符串
2021-07-23 11:05:33 +08:00
carbon.Parse("2020-08-05 13:14:15").ToRfc7231String() // Wed, 05 Aug 2020 13:14:15 GMT
2022-04-12 17:40:58 +08:00
// 输出 RFC3339 格式字符串
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToRfc3339String() // 2020-08-05T13:14:15+08:00
// 输出 RFC3339Milli 格式字符串
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToRfc3339MilliString() // 2020-08-05T13:14:15.999+08:00
// 输出 RFC3339Micro 格式字符串
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToRfc3339MicroString() // 2020-08-05T13:14:15.999999+08:00
// 输出 RFC3339Nano 格式字符串
carbon.Parse("2020-08-05T13:14:15.999999999+08:00").ToRfc3339NanoString() // 2020-08-05T13:14:15.999999999+08:00
2021-07-28 09:18:51 +08:00
// 输出日期时间字符串
fmt.Sprintf("%s", carbon.Parse("2020-08-05 13:14:15")) // 2020-08-05 13:14:15
// 输出"2006-01-02 15:04:05.999999999 -0700 MST"格式字符串
2022-04-12 17:40:58 +08:00
carbon.Parse("2020-08-05 13:14:15").ToString() // 2020-08-05 13:14:15.999999 +0800 CST
2021-07-23 11:05:33 +08:00
// 输出指定布局的字符串,Layout()是ToLayoutString()的简写
2022-04-24 22:15:44 +08:00
carbon.Parse("2020-08-05 13:14:15").Layout(carbon.ISO8601Layout) // 2020-08-05T13:14:15+08:00
2021-07-23 11:05:33 +08:00
carbon.Parse("2020-08-05 13:14:15").Layout("20060102150405") // 20200805131415
carbon.Parse("2020-08-05 13:14:15").Layout("2006年01月02日 15时04分05秒") // 2020年08月05日 13时14分15秒
2021-07-24 12:39:07 +08:00
carbon.Parse("2020-08-05 13:14:15").Layout("It is 2006-01-02 15:04:05") // It is 2020-08-05 13:14:15
2021-07-23 11:05:33 +08:00
// 输出指定格式的字符串,Format()是ToFormatString()的简写(如果使用的字母与格式化字符冲突时,请使用\符号转义该字符)
carbon.Parse("2020-08-05 13:14:15").Format("YmdHis") // 20200805131415
2021-07-23 11:05:33 +08:00
carbon.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 PM
2021-07-24 12:39:07 +08:00
carbon.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:15
2020-10-07 17:15:46 +08:00
```
2021-08-16 09:34:15 +08:00
> 更多格式化输出符号请查看附录 <a href="#format-sign-table">格式化符号表</a>
2021-02-18 14:32:31 +08:00
##### 星座
2021-08-16 09:34:15 +08:00
2021-02-23 09:32:55 +08:00
```go
// 获取星座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").Constellation() // Leo
// 是否是白羊座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsAries() // false
// 是否是金牛座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsTaurus() // false
// 是否是双子座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsGemini() // false
// 是否是巨蟹座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsCancer() // false
// 是否是狮子座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsLeo() // true
// 是否是处女座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsVirgo() // false
// 是否是天秤座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsLibra() // false
// 是否是天蝎座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsScorpio() // false
// 是否是射手座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsSagittarius() // false
// 是否是摩羯座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsCapricorn() // false
// 是否是水瓶座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsAquarius() // false
// 是否是双鱼座
2021-02-23 09:32:55 +08:00
carbon.Parse("2020-08-05 13:14:15").IsPisces() // false
```
##### 季节
2021-08-16 09:34:15 +08:00
> 按照气象划分即3-5月为春季6-8月为夏季9-11月为秋季12-2月为冬季
2020-10-07 17:15:46 +08:00
```go
// 获取季节
2021-07-12 16:20:47 +08:00
carbon.Parse("2020-08-05 13:14:15").Season() // Summer
// 本季节开始时间
2021-07-12 16:20:47 +08:00
carbon.Parse("2020-08-05 13:14:15").StartOfSeason().ToDateTimeString() // 2020-06-01 00:00:00
// 本季节结束时间
2021-07-12 16:20:47 +08:00
carbon.Parse("2020-08-05 13:14:15").EndOfSeason().ToDateTimeString() // 2020-08-31 23:59:59
// 是否是春季
2021-07-12 16:20:47 +08:00
carbon.Parse("2020-08-05 13:14:15").IsSpring() // false
// 是否是夏季
2021-07-12 16:20:47 +08:00
carbon.Parse("2020-08-05 13:14:15").IsSummer() // true
// 是否是秋季
2021-07-12 16:20:47 +08:00
carbon.Parse("2020-08-05 13:14:15").IsAutumn() // false
// 是否是冬季
2021-07-12 16:20:47 +08:00
carbon.Parse("2020-08-05 13:14:15").IsWinter() // false
2020-10-07 17:15:46 +08:00
```
2021-08-16 09:34:15 +08:00
##### 农历
> 目前仅支持公元`1900`年至`2100`年的`200`年时间跨度
2020-10-07 17:15:46 +08:00
```go
2021-08-05 19:36:51 +08:00
// 获取农历生肖
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().Animal() // 鼠
2020-10-07 17:15:46 +08:00
// 获取农历节日
2022-04-21 15:08:24 +08:00
carbon.Parse("2021-02-12 13:14:15").Lunar().Festival() // 春节
// 获取农历年月日时分秒
carbon.Parse("2020-08-05 13:14:15").Lunar().DateTime() // 2020, 6, 16, 13, 14, 15
// 获取农历年月日
carbon.Parse("2020-08-05 13:14:15").Lunar().Date() // 2020, 6, 16
// 获取农历时分秒
carbon.Parse("2020-08-05 13:14:15").Lunar().Time() // 13, 14, 15
2020-10-07 17:15:46 +08:00
// 获取农历年年份
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().Year() // 2020
// 获取农历月月份
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().Month() // 6
// 获取农历闰月月份
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().LeapMonth() // 4
// 获取农历日日期
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().Day() // 16
// 获取农历 YYYY-MM-DD HH::ii::ss 格式字符串
fmt.Sprintf("%s", carbon.Parse("2020-08-05 13:14:15").Lunar()) // 2020-06-16 13:14:15
2020-10-07 17:15:46 +08:00
// 获取农历年字符串
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().ToYearString() // 二零二零
// 获取农历月字符串
2022-04-22 10:12:28 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().ToMonthString() // 六月
2021-08-05 19:36:51 +08:00
// 获取农历天字符串
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().ToDayString() // 十六
2021-08-05 19:36:51 +08:00
// 获取农历日期字符串
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().ToDateString() // 二零二零年六月十六
2020-10-07 17:15:46 +08:00
// 是否是农历闰年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsLeapYear() // true
// 是否是农历闰月
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsLeapMonth() // false
2020-10-07 17:15:46 +08:00
// 是否是鼠年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsRatYear() // true
// 是否是牛年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsOxYear() // false
// 是否是虎年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsTigerYear() // false
// 是否是兔年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsRabbitYear() // false
// 是否是龙年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsDragonYear() // false
// 是否是蛇年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsSnakeYear() // false
// 是否是马年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsHorseYear() // false
// 是否是羊年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsGoatYear() // false
// 是否是猴年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsMonkeyYear() // false
// 是否是鸡年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsRoosterYear() // false
// 是否是狗年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsDogYear() // false
// 是否是猪年
2022-04-21 15:08:24 +08:00
carbon.Parse("2020-08-05 13:14:15").Lunar().IsPigYear() // false
// 获取农历时辰
carbon.Parse("2020-02-05 21:00:00").Lunar().DoubleHour() // 亥时
// 是否是子时
carbon.Parse("2020-03-21 00:00:00").Lunar().IsFirstDoubleHour() // true
// 是否是丑时
carbon.Parse("2020-03-21 01:00:00").Lunar().IsSecondDoubleHour() // true
// 是否是寅时
carbon.Parse("2020-03-21 03:00:00").Lunar().IsThirdDoubleHour() // true
// 是否是卯时
carbon.Parse("2020-03-21 05:00:00").Lunar().IsFourthDoubleHour() // true
// 是否是辰时
carbon.Parse("2020-03-21 07:00:00").Lunar().IsFifthDoubleHour() // true
// 是否是巳时
carbon.Parse("2020-03-21 09:00:00").Lunar().IsSixthDoubleHour() // true
// 是否是午时
carbon.Parse("2020-03-21 11:00:00").Lunar().IsSeventhDoubleHour() // true
// 是否是未时
carbon.Parse("2020-03-21 13:00:00").Lunar().IsEighthDoubleHour() // true
// 是否是申时
carbon.Parse("2020-03-21 15:00:00").Lunar().IsNinthDoubleHour() // true
// 是否是酉时
carbon.Parse("2020-03-21 17:00:00").Lunar().IsTenthDoubleHour() // true
// 是否是戌时
carbon.Parse("2020-03-21 19:00:00").Lunar().IsEleventhDoubleHour() // true
// 是否是亥时
carbon.Parse("2020-03-21 21:00:00").Lunar().IsTwelfthDoubleHour() // true
2020-10-07 17:15:46 +08:00
```
##### JSON 支持
2021-07-19 09:55:54 +08:00
###### 定义模型
2021-08-16 09:34:15 +08:00
2021-07-19 09:55:54 +08:00
```go
type Person struct {
2022-05-07 14:57:43 +08:00
Name string `json:"name"`
Age int `json:"age"`
Birthday1 carbon.DateTime `json:"birthday"`
Birthday2 carbon.DateTimeMilli `json:"birthday"`
Birthday3 carbon.DateTimeMicro `json:"birthday"`
Birthday4 carbon.DateTimeNano `json:"birthday"`
GraduatedAt1 carbon.Date `json:"graduated_at"`
GraduatedAt2 carbon.DateMilli `json:"graduated_at"`
GraduatedAt3 carbon.DateMicro `json:"graduated_at"`
GraduatedAt4 carbon.DateNano `json:"graduated_at"`
CreatedAt1 carbon.Timestamp `json:"created_at1"`
CreatedAt2 carbon.TimestampMilli `json:"created_at2"`
CreatedAt3 carbon.TimestampMicro `json:"created_at3"`
CreatedAt4 carbon.TimestampNano `json:"created_at4"`
2021-07-19 09:55:54 +08:00
}
```
###### 实例化模型
2021-08-16 09:34:15 +08:00
2021-07-19 09:55:54 +08:00
```go
person := Person {
2022-05-07 14:57:43 +08:00
Name: "gouguoyin",
Age: 18,
2022-05-20 00:02:30 +08:00
Birthday1: carbon.DateTime{carbon.Now().SubYears(18)},
Birthday2: carbon.DateTime{carbon.Now().SubYears(18)},
Birthday3: carbon.DateTime{carbon.Now().SubYears(18)},
Birthday4: carbon.DateTime{carbon.Now().SubYears(18)},
GraduatedAt1: carbon.Date{carbon.Now()},
GraduatedAt2: carbon.Date{carbon.Now()},
GraduatedAt3: carbon.Date{carbon.Now()},
GraduatedAt4: carbon.Date{carbon.Now()},
CreatedAt1: carbon.Timestamp{carbon.Now()},
CreatedAt2: carbon.TimestampMilli{carbon.Now()},
CreatedAt3: carbon.TimestampMicro{carbon.Now()},
CreatedAt4: carbon.TimestampNano{carbon.Now()},
2021-07-19 09:55:54 +08:00
}
```
###### JSON 编码
2021-08-16 09:34:15 +08:00
2021-07-19 09:55:54 +08:00
```go
data, err := json.Marshal(&person)
if err != nil {
2022-05-07 14:57:43 +08:00
// 错误处理
log.Fatal(err)
2021-07-19 09:55:54 +08:00
}
2021-08-16 09:34:15 +08:00
fmt.Printf("%s", data)
// 输出
2021-07-19 09:55:54 +08:00
{
2022-05-07 14:57:43 +08:00
"name": "gouguoyin",
"age": 18,
"birthday1": "2003-07-16 16:22:02",
"birthday2": "2003-07-16 16:22:02.999",
"birthday3": "2003-07-16 16:22:02.999999",
"birthday4": "2003-07-16 16:22:02.999999999",
"graduated_at1": "2020-08-05",
"graduated_at2": "2020-08-05.999",
"graduated_at3": "2020-08-05.999999",
"graduated_at4": "2020-08-05.999999999",
2022-05-20 00:02:30 +08:00
"created_at1": 1596604455,
"created_at2": 1596604455999,
"created_at3": 1596604455999999,
"created_at4": 1596604455999999999
2021-07-19 09:55:54 +08:00
}
```
###### JSON 解码
2021-08-16 09:34:15 +08:00
2021-07-19 09:55:54 +08:00
```go
2022-04-18 11:05:17 +08:00
str := `{
2021-08-16 09:34:15 +08:00
"name": "gouguoyin",
"age": 18,
2022-05-07 09:16:36 +08:00
"birthday1": "2003-07-16 16:22:02",
"birthday2": "2003-07-16 16:22:02.999",
"birthday3": "2003-07-16 16:22:02.999999",
"birthday4": "2003-07-16 16:22:02.999999999",
"graduated_at1": "2020-08-05",
"graduated_at2": "2020-08-05.999",
"graduated_at3": "2020-08-05.999999",
"graduated_at4": "2020-08-05.999999999",
"created_at1": 1596604455,
"created_at2": 1596604455999,
"created_at3": 1596604455999999,
"created_at4": 1596604455999999999
2021-07-19 09:55:54 +08:00
}`
person := new(Person)
2022-04-18 11:05:17 +08:00
err := json.Unmarshal([]byte(str), &person)
2021-07-19 09:55:54 +08:00
if err != nil {
2022-05-07 14:57:43 +08:00
// 错误处理
log.Fatal(err)
2021-07-19 09:55:54 +08:00
}
2021-08-23 11:32:03 +08:00
fmt.Printf("%+v", *person)
// 输出
2022-05-07 09:16:36 +08:00
{Name:gouguoyin Age:18 Birthday1:2003-07-16 16:22:02 Birthday2:2003-07-16 16:22:02.999 Birthday3:2003-07-16 16:22:02.999999 Birthday4:2003-07-16 16:22:02.999999999 GraduatedAt1:2020-08-05 GraduatedAt2:2020-08-05.999 GraduatedAt3:2020-08-05.999999 GraduatedAt4:2020-08-05.999999999 CreatedAt1:2020-08-05 13:14:15 CreatedAt2:2020-08-05 13:14:15.999 CreatedAt3:2020-08-05 13:14:15.999999 CreatedAt4:2020-08-05 13:14:15.999999999}
2021-07-19 09:55:54 +08:00
```
##### 国际化支持
目前支持的语言有
2021-08-16 09:34:15 +08:00
2021-08-06 14:38:23 +08:00
* [英语(en)](./lang/en.json "英语")
* [日语(jp)](./lang/jp.json "日语")
* [韩语(kr)](./lang/kr.json "韩语")
2021-08-05 19:36:51 +08:00
* [德语(de)](./lang/de.json "德语"): 由 [benzammour](https://github.com/benzammour "benzammour") 翻译
2022-04-18 11:05:17 +08:00
* [简体中文(zh-CN)](./lang/zh-CN.json "简体中文"): 由 [gouguoyin](https://github.com/gouguoyin "gouguoyin") 翻译
* [繁体中文(zh-TW)](./lang/zh-TW.json "繁体中文"): 由 [gouguoyin](https://github.com/gouguoyin "gouguoyin") 翻译
* [西班牙语(es)](./lang/es.json "西班牙语"): 由 [hgisinger](https://github.com/hgisinger "hgisinger") 翻译
2021-08-09 16:47:20 +08:00
* [土耳其语(tr)](./lang/tr.json "土耳其语"): 由 [emresenyuva](https://github.com/emresenyuva "emresenyuva") 翻译
2021-08-16 09:34:15 +08:00
* [葡萄牙语(pt)](./lang/pt.json "葡萄牙语"): 由 [felipear89](https://github.com/felipear89 "felipear89") 翻译
2021-08-23 11:32:03 +08:00
* [俄罗斯语(ru)](./lang/ru.json "俄罗斯语"): 由 [zemlyak](https://github.com/zemlyak "zemlyak") 翻译
2022-04-18 11:05:17 +08:00
* [乌克兰语(uk)](./lang/uk.json "乌克兰语"): 由 [open-git](https://github.com/open-git "open-git") 翻译
2022-05-20 00:02:30 +08:00
* [罗马尼亚语(ro)](./lang/ro.json "罗马尼亚语"): 由 [DrOctavius](https://github.com/DrOctavius "DrOctavius") 翻译
目前支持的方法有
2021-08-16 09:34:15 +08:00
2021-08-05 19:36:51 +08:00
* `Constellation()`:获取星座
* `Season()`:获取季节
* `DiffForHumans()`:获取对人类友好的可读格式时间差
* `ToMonthString()`:输出完整月份字符串
* `ToShortMonthString()`:输出缩写月份字符串
* `ToWeekString()`:输出完整星期字符串
* `ToShortWeekString()`:输出缩写星期字符串
###### 设置区域
2021-08-16 09:34:15 +08:00
2021-02-23 09:32:55 +08:00
```go
2021-09-10 20:49:11 +08:00
lang := carbon.NewLanguage()
2021-09-10 20:57:12 +08:00
lang.SetLocale("zh-CN")
2021-07-08 09:49:00 +08:00
c := carbon.SetLanguage(lang)
2021-09-10 20:57:12 +08:00
if c.Error != nil {
// 错误处理
log.Fatal(err)
}
2021-07-08 09:49:00 +08:00
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() // 狮子座
2021-07-12 16:20:47 +08:00
c.Now().AddHours(1).Season() // 夏季
2021-02-23 09:32:55 +08:00
```
###### 重写部分翻译资源(其余仍然按照指定的 `locale` 文件内容翻译)
2021-08-16 09:34:15 +08:00
2021-02-23 09:32:55 +08:00
```go
2021-09-10 20:49:11 +08:00
lang := carbon.NewLanguage()
2021-09-10 20:57:12 +08:00
lang.SetLocale("en")
2021-02-23 09:32:55 +08:00
resources := map[string]string {
2021-08-16 09:34:15 +08:00
"hour": "%dh",
2021-02-23 09:32:55 +08:00
}
lang.SetResources(resources)
2021-07-08 09:49:00 +08:00
c := carbon.SetLanguage(lang)
2021-09-10 20:57:12 +08:00
if c.Error != nil {
// 错误处理
log.Fatal(err)
}
2021-07-08 09:49:00 +08:00
c.Now().AddYears(1).DiffForHumans() // 1 year from now
c.Now().AddHours(1).DiffForHumans() // 1h from now
c.Now().ToMonthString() // August
c.Now().ToShortMonthString() // Aug
c.Now().ToWeekString() // Tuesday
c.Now().ToShortWeekString() // Tue
c.Now().Constellation() // Leo
2021-07-12 16:20:47 +08:00
c.Now().Season() // Summer
2021-02-23 09:32:55 +08:00
```
###### 重写全部翻译资源(无需指定 `locale`)
2021-08-16 09:34:15 +08:00
2021-02-23 09:32:55 +08:00
```go
2021-09-10 20:49:11 +08:00
lang := carbon.NewLanguage()
2021-02-23 09:32:55 +08:00
resources := map[string]string {
2021-08-16 09:34:15 +08:00
"months": "january|february|march|april|may|june|july|august|september|october|november|december",
"short_months": "jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec",
"weeks": "sunday|monday|tuesday|wednesday|thursday|friday|saturday",
"short_weeks": "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",
2021-02-23 09:32:55 +08:00
"now": "just now",
2021-08-16 09:34:15 +08:00
"ago": "%s ago",
"from_now": "in %s",
"before": "%s before",
"after": "%s after",
2021-02-23 09:32:55 +08:00
}
lang.SetResources(resources)
2021-07-08 09:49:00 +08:00
c := carbon.SetLanguage(lang)
c.Now().AddYears(1).DiffForHumans() // in 1 yr
c.Now().AddHours(1).DiffForHumans() // in 1h
2021-08-16 09:34:15 +08:00
c.Now().ToMonthString() // august
c.Now().ToShortMonthString() // aug
c.Now().ToWeekString() // tuesday
c.Now().ToShortWeekString() // tue
c.Now().Constellation() // leo
c.Now().Season() // summer
2021-07-12 16:20:47 +08:00
```
##### 错误处理
2021-08-16 09:34:15 +08:00
> 如果有多个错误发生,只返回第一个错误,前一个错误排除后才返回下一个错误
```go
2021-07-23 11:05:33 +08:00
c := carbon.SetTimezone("xxx").Parse("2020-08-05")
if c.Error != nil {
// 错误处理...
2021-02-23 09:32:55 +08:00
log.Fatal(c.Error)
}
fmt.Println(c.ToDateTimeString())
// 输出
2021-07-23 11:05:33 +08:00
invalid timezone "xxx", please see the file "$GOROOT/lib/time/zoneinfo.zip" for all valid timezones
```
2021-08-16 09:34:15 +08:00
#### 附录
2021-08-16 09:34:15 +08:00
##### <a id="format-sign-table">格式化符号表</a>
2021-08-16 09:34:15 +08:00
| 符号 | 描述 | 长度 | 范围 | 示例 |
| :------------: | :------------: | :------------: | :------------: | :------------: |
2021-08-16 09:34:15 +08:00
| d | 月份中的第几天,有前导零 | 2 | 01-31 | 02 |
| D | 缩写单词表示的周几 | 3 | Mon-Sun | Mon |
| j | 月份中的第几天,没有前导零 | - |1-31 | 2 |
| S | 第几天的英文缩写后缀一般和j配合使用 | 2 | st/nd/rd/th | th |
2021-08-16 09:34:15 +08:00
| l | 完整单词表示的周几 | - | Monday-Sunday | Monday |
| F | 完整单词表示的月份 | - | January-December | January |
| m | 数字表示的月份,有前导零 | 2 | 01-12 | 01 |
| M | 缩写单词表示的月份 | 3 | Jan-Dec | Jan |
| n | 数字表示的月份,没有前导零 | - | 1-12 | 1 |
| Y | 4 位数字完整表示的年份 | 4 | 0000-9999 | 2006 |
| y | 2 位数字表示的年份 | 2 | 00-99 | 06 |
2021-07-25 07:59:41 +08:00
| a | 小写的上午和下午标识 | 2 | am/pm | pm |
| A | 大写的上午和下午标识 | 2 | AM/PM | PM |
2021-08-16 09:34:15 +08:00
| g | 小时12 小时格式 | - | 1-12 | 3 |
2021-07-25 07:59:41 +08:00
| G | 小时24 小时格式 | - | 0-23 | 15 |
| h | 小时12 小时格式 | 2 | 00-11 | 03 |
| H | 小时24 小时格式 | 2 | 00-23 | 15 |
2021-08-16 09:34:15 +08:00
| i | 分钟 | 2 | 01-59 | 04 |
| s | 秒数 | 2 | 01-59 | 05 |
| c | ISO8601 格式日期 | - | - | 2006-01-02T15:04:05-07:00 |
| r | RFC2822 格式日期 | - | - | Mon, 02 Jan 2006 15:04:05 -0700 |
| O | 与格林威治时间相差的小时数 | - | - | -0700 |
| P | 与格林威治时间相差的小时数,小时和分钟之间有冒号分隔 | - | - | +07:00 |
| T | 时区缩写 | - | - | MST |
| W | ISO8601 格式数字表示的年份中的第几周 | - | 1-52 | 1 |
| N | ISO8601 格式数字表示的星期中的第几天 | 1 | 1-7 | 1 |
| L | 是否为闰年,如果是闰年为 1否则为 0 | 1 | 0-1 | 0 |
| U | 秒级时间戳 | 10 | - | 1611818268 |
2021-07-25 07:59:41 +08:00
| u | 毫秒 | 3 | 000-999 | 999 |
2021-08-16 09:34:15 +08:00
| w | 数字表示的周几 | 1 | 0-6 | 1 |
| t | 月份中的总天数 | 2 | 28-31 | 31 |
| z | 年份中的第几天 | - | 0-365 | 2 |
| e | 当前位置 | - | - | America/New_York |
| Q | 当前季节 | 1 | 1-4 | 1 |
| C | 当前世纪数 | - | 0-99 | 21 |
2022-05-20 00:02:30 +08:00
#### 常见问题
1、v1 和 v2 版本有什么区别?
> v1 和 v2 版本的 API 没有任何区别,只是 `language.go` 里翻译资源文件内嵌的实现方式不同v1 版本是由第三方扩展库 [packr](https://github.com/gobuffalo/packr)
> 实现的v2
> 版本是由 `golang1.16` 后内置标准库 [embed](https://pkg.go.dev/embed) 实现的,推荐使用 v2 版本。
#### 参考项目
2021-08-16 09:34:15 +08:00
2020-10-07 17:15:46 +08:00
* [briannesbitt/carbon](https://github.com/briannesbitt/Carbon)
* [jinzhu/now](https://github.com/jinzhu/now)
* [goframe/gtime](https://github.com/gogf/gf/tree/master/os/gtime)
2021-02-23 09:32:55 +08:00
* [arrow-py/arrow](https://github.com/arrow-py/arrow)
2021-07-12 16:20:47 +08:00
* [moment/moment](https://github.com/moment/moment)
2022-04-19 14:05:28 +08:00
* [iamkun/dayjs](https://github.com/iamkun/dayjs)
#### 贡献者
2022-05-20 00:02:30 +08:00
2022-04-21 15:08:24 +08:00
感谢以下所有为 `Carbon` 做出贡献的人:
2022-04-19 14:05:28 +08:00
2022-05-20 00:02:30 +08:00
<a href="https://github.com/golang-module/carbon/graphs/contributors"><img src="https://contrib.rocks/image?repo=golang-module/carbon&max=100&columns=16"/></a>
2022-04-19 14:05:28 +08:00
#### 赞助
2022-04-21 15:08:24 +08:00
`Carbon` 是一个非商业开源项目, 如果你想支持 `Carbon`, 你可以为开发者 [购买一杯咖啡](https://www.gouguoyin.cn/zanzhu.html)
2022-04-19 14:05:28 +08:00
#### 致谢
2022-04-19 14:08:24 +08:00
`Carbon`已获取免费的 JetBrains 开源许可证,在此表示感谢
2022-04-19 14:05:28 +08:00
2022-04-21 15:08:24 +08:00
<a href="https://www.jetbrains.com"><img src="https://raw.githubusercontent.com/panjf2000/illustrations/master/jetbrains/jetbrains-variant-4.png" height="100" alt="JetBrains"/></a>