处理上传的csv文件
Process csv file from upload
我有一个 gin 应用程序,它接收一个 post 请求,其中包含一个我想读取但不保存的 csv 文件。我被困在这里尝试读取 post 请求并出现以下错误消息:cannot use file (variable of type *multipart.FileHeader) as io.Reader value in argument to csv.NewReader: missing method Read
file, err := c.FormFile("file")
if err != nil {
errList["Invalid_body"] = "Unable to get request"
c.JSON(http.StatusUnprocessableEntity, gin.H{
"status": http.StatusUnprocessableEntity,
"error": errList,
})
}
r := csv.NewReader(file) // <= Error message
records, err := r.ReadAll()
for _, record := range records {
fmt.Println(record)
}
有没有我可以使用的好例子?
首先读取文件和文件头
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)
}
正如其他答案所提到的,您应该先 Open()
它。
最新版gin.Context.FromFile(string)
好像return只有两个值。
这对我有用:
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)
}
}
我有一个 gin 应用程序,它接收一个 post 请求,其中包含一个我想读取但不保存的 csv 文件。我被困在这里尝试读取 post 请求并出现以下错误消息:cannot use file (variable of type *multipart.FileHeader) as io.Reader value in argument to csv.NewReader: missing method Read
file, err := c.FormFile("file")
if err != nil {
errList["Invalid_body"] = "Unable to get request"
c.JSON(http.StatusUnprocessableEntity, gin.H{
"status": http.StatusUnprocessableEntity,
"error": errList,
})
}
r := csv.NewReader(file) // <= Error message
records, err := r.ReadAll()
for _, record := range records {
fmt.Println(record)
}
有没有我可以使用的好例子?
首先读取文件和文件头
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)
}
正如其他答案所提到的,您应该先 Open()
它。
最新版gin.Context.FromFile(string)
好像return只有两个值。
这对我有用:
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)
}
}