Golang怎么用Go实现数据导入导出平台_Golang如何支持CSV和Excel格式的批量数据导入导出【实战】

张开发
2026/5/16 15:34:07 15 分钟阅读

分享文章

Golang怎么用Go实现数据导入导出平台_Golang如何支持CSV和Excel格式的批量数据导入导出【实战】
CSV/Excel导入导出应使用encoding/csv和excelize库避免手动拼接注意UTF-8编码、流式处理大文件、字段清洗、错误精确定位、批量插入及格式标准化。CSV 导入导出用 encoding/csv 读写别自己拼字符串Go 标准库的 encoding/csv 足够可靠但很多人误以为“逗号分隔简单字符串拼接”结果遇到字段含逗号、换行、引号就崩溃。真正导入时必须用 csv.NewReader 解析导出必须用 csv.NewWriter 写入它会自动处理转义和引号包裹。读 CSV 时reader.Read() 返回的是 []string每行字段已解码不用再 strings.Split写 CSV 时调用 writer.Write([]string{a, b,c, d f}) 即可csv.Writer 自动加引号、转义注意编码标准库只支持 UTF-8如果源文件是 GBK得先用 golang.org/x/text/encoding 转码否则中文全变 ???大文件别一次性 ReadAll用循环 Read 批量入库比如每 1000 行 Exec 一次否则内存爆掉Excel 导入导出选 tealeg/xlsx 还是 qax-os/excelizetealeg/xlsx 已停止维护且不支持 .xlsx 的流式读写生产环境强烈推荐 excelize —— 它支持读写、公式、样式、大数据量流式处理而且无 CGO 依赖。导入用 f, err : excelize.OpenFile(data.xlsx)再 f.GetSheetList() 查表名f.GetRows(Sheet1) 拿二维字符串切片导出新建 f : excelize.NewFile()用 f.SetCellValue(Sheet1, A1, 标题) 写单元格最后 f.SaveAs(out.xlsx)性能关键读大 Excel 时用 f.ReadSheet(Sheet1, func(row []string) error { ... }) 流式回调避免全加载进内存注意日期Excel 存的是浮点数天数从 1900-01-01 起excelize 提供 f.GetCellValue(Sheet1, A1) 会自动转成 time.Time但前提是单元格格式设为“日期”否则拿到的是原始数字得手动 time.Date(1900, 1, 1, 0, 0, 0, 0, time.UTC).AddDate(0,0,int(days))导入失败怎么定位别只看 err ! nilCSV 或 Excel 导入常卡在某一行但错误信息只说 “parse error at line 123”实际可能是第 123 行某个字段类型不对比如期望 int 却写了空字符串或时间格式不匹配。光靠 err 不够得结合上下文。在循环读取时把当前行号、原始行内容fmt.Sprintf(%q, row)、结构体绑定错误一起打日志例如log.Printf(line %d: raw%s, err%v, i, row, err)用 strconv.Atoi 转数字前先 strings.TrimSpace 去首尾空格否则 123 直接报错Excel 里看似空的单元格GetCellValue 可能返回空字符串 或 带空格别直接 判断用 strings.TrimSpace(v) 数据库插入失败时别只记 err.Error()加上 sql.ErrNoRows 等具体判断区分是数据问题还是约束冲突并发导入要不要开 goroutine小心连接池和顺序依赖批量导入不是并发越多越快。尤其写数据库时并发争抢连接、事务隔离、主键冲突都会让吞吐下降甚至出错。 Shakespeare 一款人工智能文案软件能够创建几乎任何类型的文案。

更多文章