2 回答

TA貢獻(xiàn)1111條經(jīng)驗(yàn) 獲得超0個(gè)贊
首先讀取文件和標(biāo)頭
csvPartFile, csvHeader, openErr := r.FormFile("file")
if openErr != nil {
// handle error
}
然后從文件中讀取行
csvLines, readErr := csv.NewReader(csvPartFile).ReadAll()
if readErr != nil {
//handle error
}
您可以遍歷記錄的行
for _, line := range csvLines {
fmt.Println(line)
}

TA貢獻(xiàn)1776條經(jīng)驗(yàn) 獲得超12個(gè)贊
正如其他答案所提到的,你應(yīng)該先這樣做。
最新版本的 似乎只返回兩個(gè)值。
這對(duì)我有用:Open()gin.Context.FromFile(string)
func (c *gin.Context) {
file_ptr, err := c.FormFile("file")
if err != nil {
log.Println(err.Error())
c.Status(http.StatusUnprocessableEntity)
return
}
log.Println(file_ptr.Filename)
file, err := file_ptr.Open()
if err != nil {
log.Println(err.Error())
c.Status(http.StatusUnprocessableEntity)
return
}
defer file.Close()
records, err := csv.NewReader(file).ReadAll()
if err != nil {
log.Println(err.Error())
c.Status(http.StatusUnprocessableEntity)
return
}
for _, line := range records {
fmt.Println(line)
}
}
- 2 回答
- 0 關(guān)注
- 141 瀏覽
添加回答
舉報(bào)