javascriptjquerychartsgoogle-visualizationjquery-csv

Create Google Chart from CSV input


I am trying to create a Google Chart from CSV input.

Here is my current code (found in a tutorial), unfortunately isn't working -the result is an empty chart:

<!DOCTYPE html>
<html>
<head>
   <title>Google Chart Example</title>
   <script src="https://www.google.com/jsapi"></script>
   <script src="http://code.jquery.com/jquery-1.10.1.min.js"></script>
   <script src="jquery.csv-0.71.min.js"></script>
  <script type='text/javascript'>
        // wait till the DOM is loaded
      $(function() {
         // grab the CSV
         $.get("post.csv", function(csvString) {
            // display the contents of the CSV
            $("#chart").html(csvString);
         });
      });

// load the visualization library from Google and set a listener
google.load("visualization", "1", {packages:["corechart"]});
google.setOnLoadCallback(drawChart);

   function drawChart() {
   // grab the CSV
   $.get("miez.csv", function(csvString) {
    // transform the CSV string into a 2-dimensional array
  var arrayData = $.csv.toArrays(csvString, {onParseValue: $.csv.hooks.castToScalar});
    // this new DataTable object holds all the data
  var data = new google.visualization.arrayToDataTable(arrayData);
    // this view can select a subset of the data at a time
  var view = new google.visualization.DataView(data);
      view.setColumns([0,1]);
  var options = {
   title: "Weight tracking",
   hAxis: {title: data.getColumnLabel(0), minValue: data.getColumnRange(0).min, maxValue: data.getColumnRange(0).max},
   vAxis: {title: data.getColumnLabel(1), minValue: data.getColumnRange(1).min, maxValue: data.getColumnRange(1).max},
   legend: 'none'
    };
  var chart = new google.visualization.ScatterChart(document.getElementById('chart'));
chart.draw(view, options);
     });
    }
   </script>

</head>
<body>
   <div id="chart">

   </div>
</body>
</html>

The CSV is pretty simple, there is just date and weight.

Date,Weight
2014-10-25 09:58:30 +0000,86.025
2014-10-25 10:14:38 +0000,88.44836
2014-10-25 13:08:13 +0000,84.04703

Solution

  • The jquery-csv library provides the ability to translate a string of csv into an array to be used by google.visualization.arrayToDataTable() (their example here). To make this work, add jquery.csv.js to your server (in the example below I assume it is in the same folder as your HTML) and link to it in your <head>. The following is a simple script you can add to your <head> to get started. I assume a scatter chart, but this process works for any of the charts here. The div in which the chart is rendered has id="chart".

    // load the visualization library from Google and set a listener
    google.load("visualization", "1", {packages:["corechart"]});
    google.setOnLoadCallback(drawChart);
    
    // this has to be a global function
    function drawChart() {
       // grab the CSV
       $.get("example.csv", function(csvString) {
          // transform the CSV string into a 2-dimensional array
          var arrayData = $.csv.toArrays(csvString, {onParseValue: $.csv.hooks.castToScalar});
    
          // this new DataTable object holds all the data
          var data = new google.visualization.arrayToDataTable(arrayData);
    
          // this view can select a subset of the data at a time
          var view = new google.visualization.DataView(data);
          view.setColumns([0,1]);
    
         // set chart options
         var options = {
            title: "A Chart from a CSV!",
            hAxis: {title: data.getColumnLabel(0), minValue: data.getColumnRange(0).min, maxValue: data.getColumnRange(0).max},
            vAxis: {title: data.getColumnLabel(1), minValue: data.getColumnRange(1).min, maxValue: data.getColumnRange(1).max},
            legend: 'none'
         };
    
         // create the chart object and draw it
         var chart = new google.visualization.ScatterChart(document.getElementById('chart'));
         chart.draw(view, options);
      });
    }