Skip to content

alexscheelmeyer/csv-streamer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CSV-streamer

This is code for reading CSV files. It is very simple and only tries to fill one single need : if someone hands you a CSV file and you want to read it into your code for further processing.

It has no dependencies, except for Mocha if you want to run the tests.

The API is designed as a readable and writeable stream, making it possible to use it as part of a "pipe"-chain. Other benefits are great performance and simple but flexible interface.

Installing

npm install csv-streamer

Usage

Usually you just want to load that CSV-file :

const fs=require('fs');
const CSVStream=require('csv-streamer').Reader;
const csv=new CSVStream({ headers: true });

csv.on('data',function(line){
	//do something with the data
});
fs.createReadStream('file.csv').pipe(csv);

CSV files can be with or without a leading line with names of columns (headers). The default is no headers and in that case each data-callback will provide you with an array of the values of each line. If headers are available it will instead contain an object with the values as named properties.

If you need to know the names of the headers, you can listen for the "headers" event, it will provide you with an array of the names.

Should you have the need for parsing tab separated files or something even more wicked, you can pass a custom delimiter as part of the options object :

var csv=new CSVStream({headers:true,delimiter:'\t'});

In some cases you are offloading the data to an async destination and for this you can use the asyncdata event instead of the regular data event. It will provide a callback as the second parameter and you will not receive futher data before calling that to acknowledge you are done processing the data.

If you are so unlucky that you have CSV in a string only, you should look into wrapping the string in a stream API and then pipe that into the CSV stream. Something like this (not tested).

You can also have a look at the test folder to see some examples of using the API.

In my testing it seems to be around 33% faster compared to node-csv code by Chris Williams.

Other

Made by Alex Scheel Meyer. Released to the public domain.

Uses CSVToArray function by Ben Nadel

Inspired by the node-csv code by Chris Williams

Also see csv-stream

About

CSV reader for Node.js usable as a readable/writable stream

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published