13

次のようなcsvファイルがあります。

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

グーグルチャートを使用してそれの積み重ねられたグラフをプロットしたいと思います(週は私のx(水平)値であり、values1とvalues2はyの2つのセットです)。残念ながら、そうする簡単な方法は見つかりませんでした。それはおそらく私がjsの完全な初心者であることに関係しています。

それを行う簡単な方法はありますか?

4

3 に答える 3

17

jquery-csvライブラリは、csvの文字列を使用する配列に変換する機能を提供します(ここでgoogle.visualization.arrayToDataTable()の例)。これを機能させるには、jquery.csv.jsをサーバーに追加し(以下の例では、HTMLと同じフォルダーにあると想定しています)、にリンクします。以下は、開始するために追加できる簡単なスクリプトです。散布図を想定していますが、このプロセスはここのどのグラフでも機能します。これを機能させるには、 withも必要です。<head><head><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);
  });
}
于 2013-07-21T19:38:00.953 に答える
2

私はしばらく探していましたが、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);
}
于 2019-02-11T22:19:50.127 に答える
0

どのサーバー側スクリプト言語で作業していますか(php、asp)?

1つのオプションは、Googleドライブに保存されたスプレッドシートからデータをインポートすることです。Googleドキュメントからデータを保存および抽出するPHPベースの例については、こちらを参照してください。これにより、スプレッドシートを更新できるようになり、グラフは新しいデータを自動的にプロットします。

于 2013-01-10T13:16:58.050 に答える