如何将Google Chart与csv中的数据一起使用

时间:2013-01-08 09:16:16

标签: javascript csv google-visualization

我有一个类似的csv文件:

week,value1,value2
1,2,3
2,7,9

我想使用谷歌图表绘制它的叠加图(周是我的x(水平)值,值1和值2是两组y)。不幸的是,我没有找到任何简单的方法。这可能与我在js中成为一个完整的菜鸟有关。

有没有简单的方法呢?

3 个答案:

答案 0 :(得分:13)

jquery-csv library提供了将csv字符串转换为google.visualization.arrayToDataTable()(其示例here)使用的数组的功能。要使其工作,请将jquery.csv.js添加到您的服务器(在下面的示例中,我假设它与您的HTML位于同一文件夹中)并在<head>中链接到它。以下是一个简单的脚本,您可以添加到<head>以开始使用。我假设散点图,但此过程适用于任何图表here。您还需要<div> 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);
  });
}

答案 1 :(得分:0)

你在使用什么服务器端脚本语言(php,asp)?

一个选项可能是从Google云端硬盘保存的电子表格see here中导入数据,以获取基于PHP的保存和从Google文档中提取数据的示例。这样就可以更新电子表格,图表会自动绘制新数据。

答案 2 :(得分:0)

我已经搜索了一段时间,并在Google小组讨论中找到了解决方案。 https://groups.google.com/forum/#!topic/google-visualization-api/cnXYDr411tQ

我已经尝试过了,并且有效!

在这种情况下,我们必须指定csv文件的标头类型。

var queryOptions = {
    csvColumns: ['number', 'number', 'number' /* Or whatever the columns in the CSV file are */],
    csvHasHeader: true /* This should be false if your CSV file doesn't have a header */
}
/* csvUrl is the path to your csv */    
var query = new google.visualization.Query(csvUrl, queryOptions);
query.send(handleQueryResponse);

function handleQueryResponse(response) {

    if (response.isError()) {
        alert('Error in query: ' + response.getMessage() + ' ' + response.getDetailedMessage());
        return;
    }

    var data = response.getDataTable();

    var chart = new google.visualization.ColumnChart(document.getElementById('your div'));
    // Draw your chart with the data table here.
    // chart.draw(view, queryOptions);
}