猿问

如何使用多种格式循环解析日期?

我正在尝试读取一个巨大的 csv 文件,其中的日期列具有 2 种可能的非标准格式的值...

  1. 2015 年 12 月 28 日 -- 月//年

  2. 2013 年 11 月 2 日 -- 月//年

...意味着中间的一天部分可以是一位数或两位数。

我从这个很好的老问题中学会了如何使用格式:解析不是“标准”格式的日期/时间字符串。但是由于我要循环尝试解析每一行,所以我一次只能指定一种格式。现在它在查找不同格式的日期值时出错。也许我可以在 parse-using-format#1 失败时编写代码来捕获错误,然后应用 format#2,而不是出错。但是有人可以指出我更好/正确的方法吗?


带有日期字符串数组的示例代码:https: //play.golang.org/p/aloIQnrkOjK


package main


import (

    "fmt"

    "time"

)


func main() {

    const format = "01/02/2006" //mm/dd/yyyy

    var list [2]string = [2]string{"12/28/2015", "11/2/2013"}

    for _, data := range list {

        t, err := time.Parse(format, data)

        if err != nil {

            fmt.Println("Error is: ", err)

        } else {

            fmt.Println("Value is: ", t)

        }

    }

}

//输出:


值为:2015-12-28 00:00:00 +0000 UTC


错误是:将“11/2/2013”解析为“01/02/2006”:无法将“2/2013”解析为“02”


慕无忌1623718
浏览 97回答 1
1回答

泛舟湖上清波郎朗

问题中的代码使用一种格式解析多个日期。问题是其中一个日期与格式不匹配(当天缺少前导零)。通过使前导零可选来修复:const format = "1/2/2006" // remove zero before day (and month just in case)
随时随地看视频慕课网APP

相关分类

Go
我要回答