登录
首页 >  Golang >  Go问答

处理上传的 csv 文件

来源:stackoverflow

时间:2024-04-01 22:09:33 480浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《处理上传的 csv 文件》,文章讲解的知识点主要包括,如果你对Golang方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

问题内容

我有一个 gin 应用程序,它接收一个包含 csv 文件的发布请求,我想读取该文件而不保存它。我被困在这里尝试从发布请求中读取以下错误消息: 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) 似乎只返回两个值。
这对我有用:

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)
    }
}

今天关于《处理上传的 csv 文件》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>