duanqian3953 2018-02-12 09:27
浏览 80
已采纳

从Go-kit Golang中的API请求解析CSV文件

I am trying to build a service that takes user input of file from POST request and then iterates the CSV and passes it into my database. I am having problem to pass the file and read it. Below are my codes.

Endpoint.go

  type CSVRequest struct {
    File  io.Reader

}


func MakeCSVEndpoint(svc Service) endpoint.Endpoint {
    return func(ctx context.Context, request interface{}) (interface{}, error) {
        req := request.(CSVRequest)

        data, err := svc.ReadCSV(req.File)

        if err != nil {
            return GetErrorResponse{err}, nil
        }

        return CreateProductResponse{data}, nil
    }
}

transport.go

    func decodeCreateProductsCSV(_ context.Context, r *http.Request) (interface{}, error) {
    file, _, err := r.FormFile("file")

    return CSVRequest{File: file}, nil
}

so how can I pass the csv file to the service.go and then read and iterate the csv file and get the values of the csv file.

  • 写回答

1条回答 默认 最新

  • dongxiao_0528 2018-02-12 10:04
    关注

    Here is a basic function that can do the parsing from a POST request. The result is a two-dimensional array of strings, the first dimension being the rows and the second dimension being the values in a row. It uses the golang's own "encoding/csv" package. Go playground example available here.

    func ReadCSVFromHttpRequest(req *http.Request) ([][]string, error) {
        // parse POST body as csv
        reader := csv.NewReader(req.Body)
        var results [][]string
        for {
            // read one row from csv
            record, err := reader.Read()
            if err == io.EOF {
                break
            }
            if err != nil {
                return nil, err
            }
    
            // add record to result set
            results = append(results, record)
        }
        return results, nil
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 slam rangenet++配置
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊