我目前正在编写一个小程序,将CSV文件转换为结构体以供进一步处理。CSV行的格式如下:
20140102,09:30,38.88,38.88,38.82,38.85,67004
我有500个文件,每个文件大小约为20-30 MB。我的代码可以正常工作,但我不禁想知道是否有比我现在所做的更好的方法来转换这些文件。首先读取文件并将其转换为csv记录(伪代码)。
data, err := ioutil.ReadFile(path)
if err != nil {
...
}
r := csv.NewReader(bytes.NewReader(data))
records, err := r.ReadAll()
if err != nil {
...
}
然后循环遍历所有记录并执行
parsedTime, err := time.Parse("2006010215:04", record[0]+record[1])
if err != nil {
return model.ZorroT6{}, time.Time{}, err
}
t6.Date = ConvertToOle(parsedTime)
if open, err := strconv.ParseFloat(record[2], 32); err == nil {
t6.Open = float32(open)
}
if high, err := strconv.ParseFloat(record[3], 32); err == nil {
t6.High = float32(high)
}
if low, err := strconv.ParseFloat(record[4], 32); err == nil {
t6.Low = float32(low)
}
if close, err := strconv.ParseFloat(record[5], 32); err == nil {
t6.Close = float32(close)
}
if vol, err := strconv.ParseInt(record[6], 10,32); err == nil {
t6.Vol = int32(vol)
}
例如,我必须经过 []byte -> string -> float64 -> float32 的转换才能获得我的浮点值。我该怎么做来改善这段代码呢?
编辑:只是为了明确,我并不是真的需要提高性能,我只是更好地尝试理解Go以及可以应用于此类问题的性能优化。例如,当我有一个字节切片并且想要一个float32时,创建大量字符串和float64似乎是很多开销。