Go:time.Parse()问题

时间:2015-07-01 15:24:15

标签: parsing time go

我有以下代码:

timeLocal := "01/July/2015:18:12:25 +0900"
inFormat := "02/January/2006:15:04:05 -0700"
parsed, err := time.Parse(inFormat, timeLocal)
if err != nil {
    log.Fatal("Time format was not recognized!")
}

现在,解析工作正常。但是当我跑步时:

fmt.Println(timeLocal)
fmt.Println(inFormat)
fmt.Println(parsed)

输出结果为:

01/July/2015:18:12:25 +0900
02/January/2006:15:04:05 -0700
2015-07-01 18:12:25 +0900 +0900

第二个+0900应该在那里吗?我做的蠢事是什么?对不起,这真是漫长的一天,我不知道我错过了什么。

哦,整个文件都在这里:

package main

import (
    "fmt"
    "time"
    "log"
)

func main() {
    timeLocal := "01/July/2015:18:12:25 +0900"
    inFormat := "02/January/2006:15:04:05 -0700"
    parsed, err := time.Parse(inFormat, timeLocal)
    if err != nil {
        log.Fatal("Time format was not recognized!")
    }

    fmt.Println(timeLocal)
    fmt.Println(inFormat)
    fmt.Println(parsed)
}

2 个答案:

答案 0 :(得分:2)

Time.String使用的默认格式为:

2006-01-02 15:04:05.999999999 -0700 MST

注意" MST"部分。由于您未提供区域名称,因此格式仅为"名称"它与偏移相同,即" + 0900"。如果您将其更改为" + 0000",您会发现这确实是时区名称:

2015-07-01 18:12:25 +0000 UTC

如果您不想要,请使用单独的格式进行打印:

myFmt := "2006-01-02 15:04:05.999999999 -0700"
fmt.Println(parsed.Format(myFmt))

答案 1 :(得分:2)

如果查看time.Time的文档,您将看到默认输出格式:

  

String返回使用格式字符串格式化的时间:

     

" 2006-01-02 15:04:05.999999999 -0700 MST"

现在您应该看到第二个+0900正在做什么 - 这是一个位置(时区)名称。由于您的输入格式没有名称,因此只需重复一次偏移。

您可以通过更改输入格式来解析位置名称来提供名称。或者,如果您不需要,也可以提供不打印名称的输出格式。

您修改过的示例:

package main

import (
    "fmt"
    "time"
    "log"
)

func main() {
    timeLocal := "01/July/2015:18:12:25 +0900 XYZ"
    inFormat := "02/January/2006:15:04:05 -0700 MST"
    parsed, err := time.Parse(inFormat, timeLocal)
    if err != nil {
        log.Fatal("Time format was not recognized!")
    }

    fmt.Println(timeLocal)
    fmt.Println(inFormat)
    fmt.Println(parsed) // 2015-07-01 18:12:25 +0900 XYZ
    fmt.Println(parsed.Format("02/January/2006:15:04:05 -0700"))
}

http://play.golang.org/p/xVGvlt-M5B