我正在尝试读取一个巨大的 csv 文件,其中的日期列具有 2 种可能的非标准格式的值...
2015 年 12 月 28 日 -- 月/日/年
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”
泛舟湖上清波郎朗
相关分类