RGraph is a JavaScript charts library based on HTML5 SVG and canvas. RGraph is mature (over 15 years old) and has a wealth of features making it an ideal choice to use for showing charts on your website.

More »


Get the latest version of RGraph (version 6.18, 1st June 2024) from the download page. You can read the changelog here. There's also older versions available, minified files and links to cdnjs.com hosted libraries.

More »


RGraph can be used for free under the GPL or if that doesn't suit your situation there's an inexpensive (£129) commercial license available.

More »

CSV import utility


View example on CodePen

Since October 2013 there's been a csv reader object that is part of RGraph. This object helps you fetch and read the contents of csv files that are held on your server (though by using CORS, cross-origin HTTP requests can be made). It can also make it easier for you to get information from your database. You can have a server-based script that fetches data from your database and outputs it as csv data. Then use this csv reader to read it and get the data from it.

Alternatively, you might have a csv file that's generated by a server-based application so you can then read that file using this csv reader.

Note that the csv importer can be used standalone - so you don't need to include the RGraph core library and it's easier for you to use it with your own applications or code.

In October 2021 this csv objects api was expanded slightly to bring it into line with the HTMLTable connector.

An example

    // This fetches a csv file and shows a Bar chart
    var csv = new RGraph.CSV('/sample.csv', function (csv)
        // Get the first column which becomes the labels
        var labels = csv.column(0),
            // Get the second column which becomes the data
            data = csv.column(1),
            // Get the number of rows in the CSV
            numrows = csv.numrows,
            // Get the number of columns in the CSV
            numcols = csv.numcols;

        // Create the chart
        var bar = new RGraph.Bar({
            data: data,
            options: {
                backgroundGridVlines: false,
                backgroundGridBorder: false,
                title: 'A chart using the CSV reader',
                colors: ['#000'],
                xaxis: false,
                yaxis: false,
                marginTop: 35,
                shadow: false,
                colorsStroke: 'rgba(0,0,0,0)',
                textSize: 14,
                labelsAbove: true,
                labelsAboveSpecific: labels,
                labelsAboveSize: 14,
                labelsAboveOffset: -35,
                labelsAboveColor: 'white'

API documentation

Constructor(URL, callback[, separator[, end-of-line]])
You use the constructor to create and fetch the csv file. It takes two arguments:

row = csv.row(index[, start[, length]])
This function fetches a row of data from the csv and returns it (as an array). Optionally you can give the column index to start at (the column numbering starts from 0). eg row = csv.row(3, 1) You can also optionally give a length which stipulates how many elements are returned to you.


column = csv.column(index[, start[, length]])
This function fetches a column of data from the csv and returns it (as an array). Optionally you can give the row index to start at (the row numbering starts from 0). eg col = csv.column(3, 1)You can also optionally give a length that stipulates how many elements are returned to you.


Trailing end-of-lines

Note that trailing EOLs (eg \r\n) are stripped automatically.

Database integration

By using the csv file reader you can make integrating with a database easier. You can have a server-side script that retrieves data from the database and outputs it like this (or like this).

You can then request that csv file using the csv file reader and that allows you to get the data into RGraph.

Reading a <div> tag instead of a file

Instead of reading a csv file from your server, you can also embed the csv data into a hidden div in your page.

If your server has high response times you may prefer this in place of an extra ajax round-trip to your server to fetch the data.

The code is very similar, though instead of a filename you would use the div tags id - like this:

<script src="RGraph.common.core.js"></script>
<script src="RGraph.common.csv.js"></script>
<script src="RGraph.common.bar.js"></script>

<div id="myDiv" style="display: none">

<canvas id="cvs" width="750" height="350"></canvas>

    // This fetches the CSV data from the <div> tag above and creates a Bar chart
    var csv = new RGraph.CSV('id:myDiv', function (csv)
        // Get the first row starting with the second column
        var data = csv.get(0, 1);

        var obj = new RGraph.Bar({
            id: 'cvs',
            data: data,
            options: {
                marginInner: 20

If you use the window.onload event to create your chart(s) then that means that you can put the div tag that contains the csv data anywhere you like on the page - including below the code that creates the chart. The DOMContentLoaded event would also work equally well in this case.

Demo pages

There are lots of demos of the csv reader in the download archive They have the words csv-reader or at least csv in the filename.