publish time-formatting-parsing
This commit is contained in:
parent
2a17561156
commit
5110cee76a
@ -47,7 +47,7 @@ Regular Expressions
|
|||||||
JSON
|
JSON
|
||||||
Time
|
Time
|
||||||
Epoch
|
Epoch
|
||||||
# Time Parsing / Formatting
|
Time Formatting / Parsing
|
||||||
Random Numbers
|
Random Numbers
|
||||||
Number Parsing
|
Number Parsing
|
||||||
URL Parsing
|
URL Parsing
|
||||||
|
@ -5,3 +5,6 @@ $ go run epoch.go
|
|||||||
1351700038292387000
|
1351700038292387000
|
||||||
2012-10-31 16:13:58 +0000 UTC
|
2012-10-31 16:13:58 +0000 UTC
|
||||||
2012-10-31 16:13:58.292387 +0000 UTC
|
2012-10-31 16:13:58.292387 +0000 UTC
|
||||||
|
|
||||||
|
# Next we'll look at another time-related task: time
|
||||||
|
# parsing and formatting.
|
||||||
|
52
examples/time-formatting-parsing/time-formatting-parsing.go
Normal file
52
examples/time-formatting-parsing/time-formatting-parsing.go
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
// Go supports time formatting and parsing via
|
||||||
|
// pattern-based layouts.
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
import "time"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
p := fmt.Println
|
||||||
|
|
||||||
|
// Here's a basic example of formatting a time
|
||||||
|
// according to RFC3339.
|
||||||
|
t := time.Now()
|
||||||
|
p(t.Format("2006-01-02T15:04:05Z07:00"))
|
||||||
|
|
||||||
|
// `Format` uses an example-based layout approach; it
|
||||||
|
// takes a formatted version of the reference time
|
||||||
|
// `Mon Jan 2 15:04:05 MST 2006` to determine the
|
||||||
|
// general pattern with which to format the given
|
||||||
|
// time. Here are a few more examples of time
|
||||||
|
// formatting.
|
||||||
|
p(t.Format("4:05PM"))
|
||||||
|
p(t.Format("Mon Jan _2 15:04:05 2006"))
|
||||||
|
p(t.Format("2006-01-02T15:04:05.999999-07:00"))
|
||||||
|
|
||||||
|
// For purely numeric representations you can also
|
||||||
|
// use standard string formatting with the extracted
|
||||||
|
// components of the time value.
|
||||||
|
fmt.Printf("%d-%02d-%02dT%02d:%02d:%02d-00:00\n",
|
||||||
|
t.Year(), t.Month(), t.Day(),
|
||||||
|
t.Hour(), t.Minute(), t.Second())
|
||||||
|
|
||||||
|
// Time parsing uses the same example-based approach
|
||||||
|
// as `Format`ing. These examples parse times rendered
|
||||||
|
// with some of the layouts used above.
|
||||||
|
t1, e := time.Parse(
|
||||||
|
"2006-01-02T15:04:05.999999999-07:00",
|
||||||
|
"2012-11-01T22:08:41.117442+00:00")
|
||||||
|
p(t1)
|
||||||
|
t2, e := time.Parse(
|
||||||
|
"4:05PM",
|
||||||
|
"8:41PM")
|
||||||
|
p(t2)
|
||||||
|
|
||||||
|
// `Parse` will return an error on malformed input
|
||||||
|
// explaining the parsing problem.
|
||||||
|
_, e = time.Parse(
|
||||||
|
"Mon Jan _2 15:04:05 2006",
|
||||||
|
"8:41PM")
|
||||||
|
p(e)
|
||||||
|
}
|
@ -0,0 +1,9 @@
|
|||||||
|
$ go run time-formatting-parsing.go
|
||||||
|
2012-11-01T15:17:41-07:00
|
||||||
|
17:41PM
|
||||||
|
Thu Nov 1 15:17:41 2012
|
||||||
|
2012-11-01T15:17:41.256589-07:00
|
||||||
|
2012-11-01T15:17:41-00:00
|
||||||
|
0001-01-01 00:00:00 +0000 UTC
|
||||||
|
0000-01-01 12:08:41 +0000 UTC
|
||||||
|
parsing time "8:41PM" as "Mon Jan _2 15:04:05 2006": ...
|
@ -129,6 +129,7 @@ func debug(msg string) {
|
|||||||
|
|
||||||
var docsPat = regexp.MustCompile("^\\s*(\\/\\/|#)\\s")
|
var docsPat = regexp.MustCompile("^\\s*(\\/\\/|#)\\s")
|
||||||
var todoPat = regexp.MustCompile("\\/\\/ todo: ")
|
var todoPat = regexp.MustCompile("\\/\\/ todo: ")
|
||||||
|
var dashPat = regexp.MustCompile("\\-+")
|
||||||
|
|
||||||
type Seg struct {
|
type Seg struct {
|
||||||
Docs, DocsRendered string
|
Docs, DocsRendered string
|
||||||
@ -213,6 +214,7 @@ func parseExamples() []*Example {
|
|||||||
exampleId = strings.Replace(exampleId, " ", "-", -1)
|
exampleId = strings.Replace(exampleId, " ", "-", -1)
|
||||||
exampleId = strings.Replace(exampleId, "/", "-", -1)
|
exampleId = strings.Replace(exampleId, "/", "-", -1)
|
||||||
exampleId = strings.Replace(exampleId, "'", "", -1)
|
exampleId = strings.Replace(exampleId, "'", "", -1)
|
||||||
|
exampleId = dashPat.ReplaceAllString(exampleId, "-")
|
||||||
example.Id = exampleId
|
example.Id = exampleId
|
||||||
example.Segs = make([][]*Seg, 0)
|
example.Segs = make([][]*Seg, 0)
|
||||||
sourcePaths := mustGlob("examples/" + exampleId + "/*")
|
sourcePaths := mustGlob("examples/" + exampleId + "/*")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user