在node.js中读取csv文件的内容

Moz*_*zak 12 csv node.js express multer

我正在尝试在nodejs中实现一个模块(刚刚开始在nodejs中工作),其中有以下要求

  1. 上传.csv文件.
  2. 阅读csv文件的内容.

当前用于restful api的框架是"express":"~4.2.0"和文件上传的multer.

现在我在app.js中配置了如下所示的multer

app.use(multer({
  onFileUploadData : function(file, data){
    console.log('onFileUploadData Called with data - '+ data);
  }
}));
Run Code Online (Sandbox Code Playgroud)

在我的路径文件中,我有一个如下所示的帖子端点

app.post('/sample.csv',lead.processCSV);
Run Code Online (Sandbox Code Playgroud)

这条路线是从下面的ajax调用中调用的

$.ajax({
            xhrFields: {withCredentials: true},
            url: '/sample.csv',
            type: 'POST',
            success: function (data) {
                $scope.handleResponse(data);
            },
            error: function (error, xhr) {
                angular.element('#csvUploadBusyIcon').hide();
                alert('Oops! Upload failed');
            },
            data: formData,
            cache: false,
            contentType: false,
            processData: false
        });
Run Code Online (Sandbox Code Playgroud)

现在我想获取csv文件的内容,即当所有内容都已加载后,我应该处理我的lead.processCSV方法.

我还需要csv文件的任何其他模块,或者multer在我的情况下是否足够?

任何正确方向的建议/指导都会有所帮助.提前致谢.

Mar*_*sta 22

有一个很棒的节点项目给了我很多帮助.你应该检查一下 我们要使用的是他们的csv-parse模块.它能够将流作为输入并逐行读取而不会阻塞事件循环,因此基本上在处理文件时,服务器不会被卡住,其他请求仍然可以正常处理.

既然你说你刚开始使用nodejs,你应该快速搜索并理解中间件在请求处理过程中的工作方式.作为请求处理的简化,中间件是一个函数(req,res,next).使用req,您可以获得请求数据.使用res,您可以发送响应,然后将req和res对象发送到下一个中​​间件.这样您就可以处理部分请求,并且流的最后一个中间件将向客户端发送响应(例如res.send(200))

Multer({...})调用返回一个中间件函数.当请求到达此中间件时,multer将尝试下载用户在post请求中发送的任何文件.当你说app.use(Multer({...}))时,你要求multer尝试从任何包含文件的帖子请求中下载文件.如果并非所有路由都希望上载文件,则存在安全风险.

好吧,话虽如此,这是我为处理您的用例而编写的示例代码:

//Important Security advice: 
//don't add multer as a middleware to all requests. 
//If you do this, people will be able to upload files
//in ALL YOUR 'post' handlers!!! 

var Multer = require('multer');
var Parse = require('csv-parse');
var fs = require('fs')

function parseCSVFile(sourceFilePath, columns, onNewRecord, handleError, done){
    var source = fs.createReadStream(sourceFilePath);

    var linesRead = 0;

    var parser = Parse({
        delimiter: ',', 
        columns:columns
    });

    parser.on("readable", function(){
        var record;
        while (record = parser.read()) {
            linesRead++;
            onNewRecord(record);
        }
    });

    parser.on("error", function(error){
        handleError(error)
    });

    parser.on("end", function(){
        done(linesRead);
    });

    source.pipe(parser);
}

//We will call this once Multer's middleware processed the request
//and stored file in req.files.fileFormFieldName

function parseFile(req, res, next){
    var filePath = req.files.file.path;
    console.log(filePath);
    function onNewRecord(record){
        console.log(record)
    }

    function onError(error){
        console.log(error)
    }

    function done(linesRead){
        res.send(200, linesRead)
    }

    var columns = true; 
    parseCSVFile(filePath, columns, onNewRecord, onError, done);

}

//this is the route handler with two middlewares. 
//First:  Multer middleware to download file. At some point,
//this middleware calls next() so process continues on to next middleware
//Second: use the file as you need

app.post('/upload', [Multer({dest:'./uploads'}), parseFile]);
Run Code Online (Sandbox Code Playgroud)

我希望这有帮助.确保了解路由中间件如何在节点中工作:它们是高质量代码的关键.

马塞尔