注意事项:gtime.Time对象通过Format方法来实现自定义格式的时间日期转换,该方法与标准库time.TimeFormat方法冲突。在gtime.Time对象中,通过Layout方法实现标准库time.TimeFormat格式,例如:t.Layout(`2006-01-02 15:04:05`)

以下是gtime模块支持的时间格式语法列表:

格式说明返回值示例
----
d月份中的第几天,有前导零的 2 位数字01 到 31
D星期中的第几天,文本表示,3 个字母Mon 到 Sun
NISO-8601 格式数字表示的星期中的第几天1(表示星期一)到 7(表示星期天)
j月份中的第几天,没有前导零1 到 31
l("L"的小写字母)星期几,完整的文本格式Sunday 到 Saturday
S每月天数后面的英文后缀,2 个字符st,nd,rd 或者 th。可以和 j 一起用
w星期中的第几天,数字表示0(表示星期天)到 6(表示星期六)
z年份中的第几天0 到 365
----
WISO-8601 格式年份中的第几周,每周从星期一开始例如:42(当年的第 42 周)
----
F月份,完整的文本格式January 到 December
m数字表示的月份,有前导零01 到 12
M三个字母缩写表示的月份Jan 到 Dec
n数字表示的月份,没有前导零1 到 12
t指定的月份有几天28 到 31
----
Y4 位数字完整表示的年份例如:1999 或 2003
y2 位数字表示的年份例如:99 或 03
时间----
a小写的上午和下午值am 或 pm
A大写的上午和下午值AM 或 PM
g小时,12 小时格式,没有前导零1 到 12
G小时,24 小时格式,没有前导零0 到 23
h小时,12 小时格式,有前导零01 到 12
H小时,24 小时格式,有前导零00 到 23
i有前导零的分钟数00 到 59
s秒数,有前导零00 到 59
u毫秒数(3位)例如:000, 123, 239
UUNIX时间戳(秒)例如:1559648183
时区----
O与UTC相差的小时数例如:+0200
P与UTC的差别,小时和分钟之间有冒号分隔例如:+02:00
T时区缩写例如:UTC,GMT,CST
日期----
cISO 8601 格式的日期例如:2004-02-12T15:19:21+00:00
rRFC 822 格式的日期例如:Thu, 21 Dec 2000 16:01:07 +0200



  • No labels

3 Comments

  1. gtime 毫秒格式的时候,默认加一个小数点。  举个列子,匹配 2023-11-15 16:42:52:341 这种格式 ,设置gtime的时间格式 是 “Y-m-d H:i:s:u”  匹配出错,错误显示 2006-01-02 15:04:05:.000 个小数点。是我使用的问题吗? 

    1. .000是标准库的毫秒匹配格式

  2. 第378行有飘红提示:

        case t != nil && u == nil:,提示:tautological condition: non-nil != nilnilnesscond

    这里的源代码:
    // After reports whether the time instant t is after u.
    func (t *Time) After(u *Time) bool {
        switch {
        case t == nil:
            return false
        case t != nil && u == nil:
            return true
        default:
            return t.Time.After(u.Time)
        }
    }

    其中case t == nil,已经过滤了t ==nil的情况,后面    case t != nil && u == nil:这里是重复判断了,可以少写一个判断条件,建议代码修改为:
    func (t *Time) After(u *Time) bool {
        switch {
        case t == nil:
            return false
        case u == nil:
            return true
        default:
            return t.Time.After(u.Time)
        }
    }