Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can I read a local file with Papa Parse?

Tags:

How can I read a local file with Papa Parse? I have a file locally called challanges.csv, but after many tried I can't parse it with Papa Parse.

var data;  Papa.parse('challanges.csv', {   header: true,   dynamicTyping: true,   complete: function(results) {     console.log(results);     data = results.data;   } }); 

As far as I know, I'm having problems with opening the csv file as File. How can I do it with javascript?

like image 216
adamb Avatar asked Apr 10 '18 11:04

adamb


People also ask

How do I read a csv file in JavaScript?

parse("http://example.com/bigfoo.csv", { download: true, step: function(row) { console. log("Row:", row. data); }, complete: function() { console. log("All done!"); } });


1 Answers

The File API suggested by papaparse's docs is meant for browser used. Assuming that you are running this on node at server side, what works for me is leveraging the readable stream:

const fs = require('fs'); const papa = require('papaparse'); const file = fs.createReadStream('challenge.csv'); var count = 0; // cache the running count papa.parse(file, {     worker: true, // Don't bog down the main thread if its a big file     step: function(result) {         // do stuff with result     },     complete: function(results, file) {         console.log('parsing complete read', count, 'records.');      } }); 

There may be an easier interface, but so far this works quite well and offer the option of streaming for processing large files.

like image 56
Philip M. Avatar answered Oct 13 '22 14:10

Philip M.