Fast and powerful CSV (delimited text) parser that gracefully handles large files and malformed input
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Ville Hytönen 9155dd5b74 Add header to config in unparse in player.js. 7 years ago
player Add header to config in unparse in player.js. 7 years ago
tests Load mocha as first script on test scenario 7 years ago
.eslintrc.js Enable more linting rules (#486) 7 years ago
.gitignore Ignore yarn.lock (#480) 7 years ago
.npmignore Updated README and all manifest files 10 years ago
.travis.yml Remove support for node 0.12 (#478) 7 years ago
Gruntfile.js Enable more linting rules (#486) 7 years ago
LICENSE Build, version 4.1.0 10 years ago
README.md Remove support for node 0.12 (#478) 7 years ago
bower.json Minor version bump, 4.1.1 10 years ago
package.json Minor version bump 7 years ago
papaparse.js Minor version bump 7 years ago
papaparse.min.js Minor version bump 7 years ago

README.md

Parse CSV with JavaScript

Papa Parse is the fastest in-browser CSV (or delimited text) parser for JavaScript. It is reliable and correct according to RFC 4180, and it comes with these features:

  • Easy to use
  • Parse CSV files directly (local or over the network)
  • Fast mode (is really fast)
  • Stream large files (even via HTTP)
  • Reverse parsing (converts JSON to CSV)
  • Auto-detect delimiter
  • Worker threads to keep your web page reactive
  • Header row support
  • Pause, resume, abort
  • Can convert numbers and booleans to their types
  • Optional jQuery integration to get files from <input type="file"> elements
  • One of the only parsers that correctly handles line-breaks and quotations

Papa Parse has no dependencies - not even jQuery.

Install

papaparse is available on npm. It can be installed with the following command:

npm install papaparse

If you don't want to use npm, papaparse.min.js can be downloaded to your project source.

Homepage & Demo

To learn how to use Papa Parse:

The website is hosted on on Github Pages. If you want to contribute just clone the gh-branch of this repository and open a pull request.

Papa Parse for Node

Papa Parse can parse a Readable Stream instead of a File when used in Node.js environments (in addition to plain strings). In this mode, encoding must, if specified, be a Node-supported character encoding. The Papa.LocalChunkSize, Papa.RemoteChunkSize , download, withCredentials and worker config options are unavailable.

Get Started

For usage instructions, see the homepage and, for more detail, the documentation.

Tests

Papa Parse is under test. Download this repository, run npm install, then npm test to run the tests.

Contributing

To discuss a new feature or ask a question, open an issue. To fix a bug, submit a pull request to be credited with the contributors! Remember, a pull request, with test, is best. You may also discuss on Twitter with #PapaParse or directly to me, @mholt6.

If you contribute a patch, ensure the tests suite is running correctly. We run continuous integration on each pull request and will not accept a patch that breaks the tests.