GoFrame 프레임워크의 gtime 모듈 분석 및 사용자 정의 시간 형식 구문
这篇文章给大家分享的内容是关于GoFrame框架之gtime时间模块和支持自定义时间格式化语法,有一定的参考价值,有需要的朋友可以参考一下。
通用时间管理模块,封装了常用的时间/日期相关的方法。并支持自定义的日期格式化语法,格式化语法类似PHP的date语法。
使用方式:
import "gitee.com/johng/gf/g/os/gtime"
方法列表: godoc.org/github.com/johng-cn/gf/g/os/gtime
时间格式
gtime
模块最大的特点是支持自定义的时间格式,参考PHP日期时间格式语法,以下是支持的时间格式语法列表:
时间对象
方法列表:
type Time func New(t ...time.Time) *Time func NewFromStr(str string) *Time func NewFromStrFormat(str string, format string) *Time func NewFromStrLayout(str string, layout string) *Time func NewFromTime(t time.Time) *Time func NewFromTimeStamp(timestamp int64) *Time func Now() *Time func (t *Time) Add(d time.Duration) *Time func (t *Time) AddDate(years int, months int, days int) *Time func (t *Time) Clone() *Time func (t *Time) Format(format string) string func (t *Time) Layout(layout string) string func (t *Time) Local() *Time func (t *Time) Microsecond() int64 func (t *Time) Millisecond() int64 func (t *Time) Nanosecond() int64 func (t *Time) Round(d time.Duration) *Time func (t *Time) Second() int64 func (t *Time) String() string func (t *Time) ToLocation(location *time.Location) *Time func (t *Time) ToTime() time.Time func (t *Time) Truncate(d time.Duration) *Time func (t *Time) UTC() *Time
创建gtime.Time
对象可以通过标准库time.Time
对象、Unix时间戳、时间字符串(如:2018-07-18 12:01:00)、自定义时间字符串(需要给定格式,支持自定义格式及标准库格式)。
示例1,自定义时间格式化语法
package main import ( "fmt" "gitee.com/johng/gf/g/os/gtime" ) func main() { formats := []string{ "Y-m-d H:i:s.u", "D M d H:i:s T O Y", "\\T\\i\\m\\e \\i\\s: h:i:s a", "2006-01-02T15:04:05.000000000Z07:00", } t := gtime.Now() for _, f := range formats { fmt.Println(t.Format(f)) } }
在该示例中,我们给定了四种format格式,并将当前时间用这四种格式转换后打印出来。执行后,输出结果如下:
2018-07-22 11:17:13.797 Sun Jul 22 11:17:13 CST +0800 2018 Time is: 11:17:13 am 2006-01-02CST15:04:05.000000000Z07:00
可以看到,这个示例演示了几个需要注意的地方:
如果使用的字母与格式化字符冲突时,可以使用
\
符号转移该字符,这样时间格式解析器会认为该字符不是格式化字符,而是普通字母。因此这里的第三个字符串示例输出为:Time is: 11:17:13 am
使用
Format
方法接收的是自定义的时间格式化语法(如:Y-m-d H:i:s
),而不是标准库的事件格式语法(如:2006-01-02 15:04:05
),且两种语法不能混用,因此在这里的第四个字符串示例中原样输出参数值;
示例2,标准库时间格式化语法
package main import ( "fmt" "gitee.com/johng/gf/g/os/gtime" ) func main() { formats := []string{ "2006-01-02 15:04:05.000", "Mon Jan _2 15:04:05 MST 2006", "Time is: 03:04:05 PM", "2006-01-02T15:04:05.000000000Z07:00 MST", } t := gtime.Now() for _, f := range formats { fmt.Println(t.Layout(f)) } }
在该示例中,我们使用四种标准库的时间格式化语法格式化当前的时间并输出结果到终端。执行后,输出结果为:
2018-07-22 11:28:13.945 Sun Jul 22 11:28:13 CST 2018 Time is: 11:28:13 AM 2018-07-22T11:28:13.945153275+08:00 CST
根绝这个示例,也有几个需要说明的地方:
自定义时间格式化语法与标准库时间格式化语法并不冲突,前者使用
Format
方法,后者使用Layout
语法进行格式化,相互独立,互不冲突,无法混用;标准库的时间格式化语法自有特点,是不是感觉有点复杂;
示例3,时间对象链式操作
package main import ( "fmt" "gitee.com/johng/gf/g/os/gtime" "time" ) func main() { // 去年今日 fmt.Println(gtime.Now().AddDate(-1, 0, 0).Format("Y-m-d")) // 去年今日,UTC时间 fmt.Println(gtime.Now().AddDate(-1, 0, 0).Format("Y-m-d H:i:s T")) fmt.Println(gtime.Now().AddDate(-1, 0, 0).UTC().Format("Y-m-d H:i:s T")) // 下个月1号凌晨0点整 fmt.Println(gtime.Now().AddDate(0, 1, 0).Format("Y-m-d 00:00:00")) // 2个小时前 fmt.Println(gtime.Now().Add(-time.Hour).Format("Y-m-d H:i:s")) }
执行后,输出结果为:
2017-07-22 2017-07-22 11:42:36 CST 2017-07-22 03:42:36 UTC 2018-08-22 00:00:00 2018-07-22 10:42:36
该示例比较简单,便不多赘述。
工具方法
godoc.org/github.com/johng-cn/gf/g/os/gtime
func Date() string func Datetime() string func Microsecond() int64 func Millisecond() int64 func Nanosecond() int64 func Second() int64 func SetInterval(t time.Duration, callback func() bool) func SetTimeZone(zone string) error func SetTimeout(t time.Duration, callback func()) func StrToTime(str string) (time.Time, error) func StrToTimeFormat(str string, format string) (time.Time, error) func StrToTimeLayout(str string, layout string) (time.Time, error)
方法比较简单,比较常用的是以下几个方法;
Second
用于获得当前时间戳,Millisecond
、Microsecond
及Nanosecond
用于获得当前的毫秒、微秒和纳秒值;Date
和Datetime
用于获得当前日期及当前日期时间;SetTimeZone
用于设置当前进程的全局时区;其他方法说明请查看接口文档;
简单示例:
package main import ( "fmt" "gitee.com/johng/gf/g/os/gtime" ) func main() { fmt.Println("Date :", gtime.Date()) fmt.Println("Datetime :", gtime.Datetime()) fmt.Println("Second :", gtime.Second()) fmt.Println("Millisecond:", gtime.Millisecond()) fmt.Println("Microsecond:", gtime.Microsecond()) fmt.Println("Nanosecond :", gtime.Nanosecond()) }
执行后,输出结果为:
Date : 2018-07-22 Datetime : 2018-07-22 11:52:22 Second : 1532231542 Millisecond: 1532231542688 Microsecond: 1532231542688688 Nanosecond : 1532231542688690259
相关推荐:
自己搭建一个 Laravel 的 Docker的开发环境的方法
위 내용은 GoFrame 프레임워크의 gtime 모듈 분석 및 사용자 정의 시간 형식 구문의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

settings.json 파일은 사용자 수준 또는 작업 공간 수준 경로에 있으며 VSCODE 설정을 사용자 정의하는 데 사용됩니다. 1. 사용자 수준 경로 : Windows는 C : \ Users \\ AppData \ Roaming \ Code \ User \ Settings.json, MacOS IS /users//library/applicationsupport/code/user/settings.json, linux는 /home//.config/code/user/settings.json; 2. Workspace 수준 경로 : .vscode/settings project root 디렉토리

GO의 HTTP 로그 미들웨어는 요청 방법, 경로, 클라이언트 IP 및 시간 소모를 기록 할 수 있습니다. 1. http.handlerfunc를 사용하여 프로세서를 랩핑하고, 2. 다음에 전화하기 전후 시작 시간과 종료 시간을 기록하십시오. 전체 샘플 코드는 실행중인 것으로 확인되었으며 중소형 프로젝트를 시작하는 데 적합합니다. 확장 제안에는 상태 코드 캡처, JSON 로그 지원 및 요청 ID 추적이 포함됩니다.

TestHepdFinanotherAppTodeMineifTheissueiswithTheFileoredge.2

ustuzzleforrobusthtttprequestswithHeadSandtimeouts.2.parsehtMleffiallywithSymfonyDomcraWlerusingcsSelectors.3. handlejavaScript-heaVysitesByIntegratingPuppetErgateErgateEcpExec () TorenderPages.4.Resptobots.txt, AddDelays, andUsepoTecpexec () TorenderPages

YII의 마스터가 되려면 다음 기술을 마스터해야합니다. 1) YII의 MVC 아키텍처 이해, 2) Activerecordorm 사용에 능숙합니다. 3) GII 코드 생성 도구, 4) 마스터 YII의 검증 규칙, 5) 데이터베이스 쿼리 성능을 최적화하십시오. 이러한 기술의 학습과 실습을 통해 YII 프레임 워크 하의 개발 기능을 포괄적으로 개선 할 수 있습니다.

올바른 htmlinput 유형을 선택하면 데이터 정확도를 향상시키고 사용자 경험을 향상 시키며 유용성을 향상시킬 수 있습니다. 1. 텍스트, 이메일, 전화, 번호 및 날짜와 같은 데이터 유형에 따라 해당 입력 유형을 선택하여 자동으로 체크섬 및 키보드에 적응할 수 있습니다. 2. HTML5를 사용하여보다 직관적 인 상호 작용 방법을 제공 할 수있는 URL, 색상, 범위 및 검색과 같은 새로운 유형을 추가하십시오. 3. 자리 표시 자 및 필요한 속성을 사용하여 양식 충전의 효율성과 정확성을 향상 시키지만 자리 표시자는 레이블을 대체 할 수 없다는 점에 유의해야합니다.

mongodbgo 드라이버를 설치하고 mongo.connect ()를 사용하여 연결을 설정하여 핑을 통해 연결을 성공적으로 수행 할 수 있습니다. 2. BSON 태그가있는 GO 구조를 정의하여 MongoDB 문서를 매핑하고 선택적으로 Primitive.Objectid를 ID 유형으로 사용합니다. 3. InsertOne을 사용하여 단일 문서를 삽입하고 단일 문서를 찾아서 Mongo.errnodocuments 오류를 처리하고, 문서를 업데이트하고, 문서를 삭제하고, COOPERATES와 COOPERATES를 찾으려면 여러 문서를 얻으려면; 4. 요청 매달려 피하기 위해 항상 시간 초과 컨텍스트를 사용하고 Mon을 재사용하십시오.

BreakexitsTheloopimmed SeeforFindingAtArget, 이상적으로 THEFIRSTMATCH.2.ContInuesKIPSTheCurrentitation, 유용한 ortipilteringItemSliketemporaryFiles.3.gotoJumpStoalabeledStatement, 허용 가능한 원형 곡물 류 횡단 부산물
