2016-11-19 9 views
2

複数の行を含むグラフをGoogle視覚化Apiで作成しようとしています。私はJSONを使ってチャートにデータを追加します。Google Visualization - 複数のDataTableに参加するにはどうすればいいですか?

初めに作成された複数ののDataTableがあります - テーブルの数は、JSONキーの数に等しいです。

EDIT:私は元の問題の答えをループなしで見つけました。 SO Answer - 答えは、1つのグラフに2行を描画することです。コメントでは、複数の行でこれを行う方法についての答えがあります - このJSFiddle:JSFiddle - Multiple linesしかし私は私の場合にこの答えを使う方法をまだ分かりません。

問題は、最初と最後の2行しか描画しないということですか?私はそれは、この行で発生しますと仮定:すべてのDataTableに参加しようで

joinedData = google.visualization.data.join(joinedData, datatable, 'full', [[0, 0]], [1], [1]); 

ので、すべての行がチャートに表示されるはずです。しかし、実際には、なぜそれが正しく動作しないのかという手がかりはありません。 JSFIDDLE

function drawChart() { 
     var google_chart_json = {"Whirpool.cz": [[[2016, 11, 2], 156.0], [[2016, 11, 3], 69.0], [[2016, 11, 4], 126.0], [[2016, 11, 5], 67.0], [[2016, 11, 6], 97.0], [[2016, 11, 7], 193.0], [[2016, 11, 8], 96.0], [[2016, 11, 9], 64.0], [[2016, 11, 10], 117.0], [[2016, 11, 11], 190.0]], "Mall.cz": [[[2016, 11, 2], 95.0], [[2016, 11, 3], 98.0], [[2016, 11, 4], 158.0], [[2016, 11, 5], 160.0], [[2016, 11, 6], 191.0], [[2016, 11, 7], 106.0], [[2016, 11, 8], 51.0], [[2016, 11, 9], 158.0], [[2016, 11, 10], 89.0], [[2016, 11, 11], 154.0]], "Mall.sk": [[[2016, 11, 2], 72.0], [[2016, 11, 3], 108.0], [[2016, 11, 4], 175.0], [[2016, 11, 5], 81.0], [[2016, 11, 6], 123.0], [[2016, 11, 7], 188.0], [[2016, 11, 8], 52.0], [[2016, 11, 9], 196.0], [[2016, 11, 10], 199.0], [[2016, 11, 11], 117.0]], "Teshop.cz": [[[2016, 11, 2], 93.0], [[2016, 11, 3], 71.0], [[2016, 11, 4], 59.0], [[2016, 11, 5], 101.0], [[2016, 11, 6], 86.0], [[2016, 11, 7], 139.0], [[2016, 11, 8], 110.0], [[2016, 11, 9], 75.0], [[2016, 11, 10], 183.0], [[2016, 11, 11], 156.0]], "Gamepro.cz": [[[2016, 11, 2], 89.0], [[2016, 11, 3], 104.0], [[2016, 11, 4], 62.0], [[2016, 11, 5], 190.0], [[2016, 11, 6], 172.0], [[2016, 11, 7], 109.0], [[2016, 11, 8], 183.0], [[2016, 11, 9], 88.0], [[2016, 11, 10], 89.0], [[2016, 11, 11], 106.0]], "Gamepro.sk": [[[2016, 11, 2], 133.0], [[2016, 11, 3], 173.0], [[2016, 11, 4], 102.0], [[2016, 11, 5], 151.0], [[2016, 11, 6], 119.0], [[2016, 11, 7], 172.0], [[2016, 11, 8], 139.0], [[2016, 11, 9], 177.0], [[2016, 11, 10], 174.0], [[2016, 11, 11], 141.0]], "Datart.cz": [[[2016, 11, 2], 77.0], [[2016, 11, 3], 120.0], [[2016, 11, 4], 116.0], [[2016, 11, 5], 60.0], [[2016, 11, 6], 179.0], [[2016, 11, 7], 162.0], [[2016, 11, 8], 151.0], [[2016, 11, 9], 123.0], [[2016, 11, 10], 138.0], [[2016, 11, 11], 109.0]], "Ockosice.sk": [[[2016, 11, 2], 83.0], [[2016, 11, 3], 111.0], [[2016, 11, 4], 185.0], [[2016, 11, 5], 199.0], [[2016, 11, 6], 133.0], [[2016, 11, 7], 142.0], [[2016, 11, 8], 61.0], [[2016, 11, 9], 74.0], [[2016, 11, 10], 168.0], [[2016, 11, 11], 128.0]], "Bestmarket.sk": [[[2016, 11, 2], 174.0], [[2016, 11, 3], 154.0], [[2016, 11, 4], 180.0], [[2016, 11, 5], 87.0], [[2016, 11, 6], 193.0], [[2016, 11, 7], 105.0], [[2016, 11, 8], 106.0], [[2016, 11, 9], 115.0], [[2016, 11, 10], 185.0], [[2016, 11, 11], 159.0]]}; 
     var datas = []; 
     $.each(google_chart_json, function (key, val) { 
      var domain = key; 
      var data = new google.visualization.DataTable(); 
      data.addColumn('date', domain + 'Date'); 
      data.addColumn('number', domain); 


      $.each(val, function (_, scan) { 
       var year = scan[0][0]; 
       var month = scan[0][1]; 
       var day = scan[0][2]; 
       var price = scan[1]; 

       data.addRows([ 
        [new Date(year, month, day), price] 
       ]); 
      }); 
      datas.push(data); 
     }); 
     var joinedData = datas[0]; 
     $.each(datas, function (index, datatable) { 
      console.log('joining index '+index) 
      if (index != 0) { 
       joinedData = google.visualization.data.join(joinedData, datatable, 'full', [[0, 0]], [1], [1]); 
      } 
     }); 


     var chart = new google.visualization.LineChart(document.querySelector('#chart_div')); 
     chart.draw(joinedData, { 
      height: 300, 
      width: 600, 
      interpolateNulls: true, 
      explorer: { 
       maxZoomOut: 2, 
       keepInBounds: true 
      }, 
     }); 
    } 
    google.load('visualization', '1', {packages: ['corechart'], callback: drawChart}); 

答えて

3

最初、必要性がまたはより良い -

var joinedData = datas[0]; 
    $.each(datas, function (index, data1) { 
     if (index != 0) { 
      joinedData = google.visualization.data.join(joinedData, data1, 'full', [[0, 0]], [1], [1]); 
     } 
    }); 

そして、これが全体のスクリプトです:Join

これは、全体の加入ループは次のとおりです。

ドキュメントを登録しよう最新のライブラリ()を使用する0)
release notesによると...

jsapiローダー経由で利用可能なまま、Googleのチャートのバージョンは、もはや一貫して更新されていません。新しい静的ローダーを今から使用してください。

これを含める...
<script src="https://www.gstatic.com/charts/loader.js"></script>

ないこの...
<script src="http://www.google.com/jsapi"></script>

これは
google.load('visualization', '1', {packages: ['corechart'], callback: drawChart});

に...からload文を変更します。.. 。
google.charts.load('current', {packages: ['corechart'], callback: drawChart});

、理由2つだけの行(列)最終データテーブルにそれを作る、
は第5引数それぞれ有する(dt1Columns
参加、最初のデータ列に関係してい

代わりに、最初のテーブルから[1]含まれ、引数はそれぞれ一緒に成長する必要があり参加
[1][1,2][1,2,3]

function drawChart() { 
 
    var google_chart_json = {"Whirpool.cz": [[[2016, 11, 2], 156.0], [[2016, 11, 3], 69.0], [[2016, 11, 4], 126.0], [[2016, 11, 5], 67.0], [[2016, 11, 6], 97.0], [[2016, 11, 7], 193.0], [[2016, 11, 8], 96.0], [[2016, 11, 9], 64.0], [[2016, 11, 10], 117.0], [[2016, 11, 11], 190.0]], "Mall.cz": [[[2016, 11, 2], 95.0], [[2016, 11, 3], 98.0], [[2016, 11, 4], 158.0], [[2016, 11, 5], 160.0], [[2016, 11, 6], 191.0], [[2016, 11, 7], 106.0], [[2016, 11, 8], 51.0], [[2016, 11, 9], 158.0], [[2016, 11, 10], 89.0], [[2016, 11, 11], 154.0]], "Mall.sk": [[[2016, 11, 2], 72.0], [[2016, 11, 3], 108.0], [[2016, 11, 4], 175.0], [[2016, 11, 5], 81.0], [[2016, 11, 6], 123.0], [[2016, 11, 7], 188.0], [[2016, 11, 8], 52.0], [[2016, 11, 9], 196.0], [[2016, 11, 10], 199.0], [[2016, 11, 11], 117.0]], "Teshop.cz": [[[2016, 11, 2], 93.0], [[2016, 11, 3], 71.0], [[2016, 11, 4], 59.0], [[2016, 11, 5], 101.0], [[2016, 11, 6], 86.0], [[2016, 11, 7], 139.0], [[2016, 11, 8], 110.0], [[2016, 11, 9], 75.0], [[2016, 11, 10], 183.0], [[2016, 11, 11], 156.0]], "Gamepro.cz": [[[2016, 11, 2], 89.0], [[2016, 11, 3], 104.0], [[2016, 11, 4], 62.0], [[2016, 11, 5], 190.0], [[2016, 11, 6], 172.0], [[2016, 11, 7], 109.0], [[2016, 11, 8], 183.0], [[2016, 11, 9], 88.0], [[2016, 11, 10], 89.0], [[2016, 11, 11], 106.0]], "Gamepro.sk": [[[2016, 11, 2], 133.0], [[2016, 11, 3], 173.0], [[2016, 11, 4], 102.0], [[2016, 11, 5], 151.0], [[2016, 11, 6], 119.0], [[2016, 11, 7], 172.0], [[2016, 11, 8], 139.0], [[2016, 11, 9], 177.0], [[2016, 11, 10], 174.0], [[2016, 11, 11], 141.0]], "Datart.cz": [[[2016, 11, 2], 77.0], [[2016, 11, 3], 120.0], [[2016, 11, 4], 116.0], [[2016, 11, 5], 60.0], [[2016, 11, 6], 179.0], [[2016, 11, 7], 162.0], [[2016, 11, 8], 151.0], [[2016, 11, 9], 123.0], [[2016, 11, 10], 138.0], [[2016, 11, 11], 109.0]], "Ockosice.sk": [[[2016, 11, 2], 83.0], [[2016, 11, 3], 111.0], [[2016, 11, 4], 185.0], [[2016, 11, 5], 199.0], [[2016, 11, 6], 133.0], [[2016, 11, 7], 142.0], [[2016, 11, 8], 61.0], [[2016, 11, 9], 74.0], [[2016, 11, 10], 168.0], [[2016, 11, 11], 128.0]], "Bestmarket.sk": [[[2016, 11, 2], 174.0], [[2016, 11, 3], 154.0], [[2016, 11, 4], 180.0], [[2016, 11, 5], 87.0], [[2016, 11, 6], 193.0], [[2016, 11, 7], 105.0], [[2016, 11, 8], 106.0], [[2016, 11, 9], 115.0], [[2016, 11, 10], 185.0], [[2016, 11, 11], 159.0]]}; 
 
    var datas = []; 
 
    $.each(google_chart_json, function (key, val) { 
 
     var domain = key; 
 
     var data = new google.visualization.DataTable(); 
 
     data.addColumn('date', domain + 'Date'); 
 
     data.addColumn('number', domain); 
 

 
     $.each(val, function (_, scan) { 
 
      var year = scan[0][0]; 
 
      var month = scan[0][1]; 
 
      var day = scan[0][2]; 
 
      var price = scan[1]; 
 

 
      data.addRows([ 
 
       [new Date(year, month, day), price] 
 
      ]); 
 
     }); 
 
     datas.push(data); 
 
    }); 
 
    var joinedData = datas[0]; 
 
    var columns = []; 
 
    $.each(datas, function (index, datatable) { 
 
     if (index != 0) { 
 
      columns.push(index); 
 
      joinedData = google.visualization.data.join(joinedData, datatable, 'full', [[0, 0]], columns, [1]); 
 
     } 
 
    }); 
 

 
    var chart = new google.visualization.LineChart(document.querySelector('#chart_div')); 
 
    chart.draw(joinedData, { 
 
     height: 300, 
 
     width: 600, 
 
     interpolateNulls: true, 
 
     explorer: { 
 
      maxZoomOut: 2, 
 
      keepInBounds: true 
 
     }, 
 
    }); 
 
} 
 
google.charts.load('current', {packages: ['corechart'], callback: drawChart});
<script src="https://code.jquery.com/jquery-1.12.4.js"></script> 
 
<script src="https://www.gstatic.com/charts/loader.js"></script> 
 
<div id="chart_div"></div>

+0

は、私は非常に同じようなことやった、ありがとう...作業スニペット以下を参照してください - 'フル'、データテーブルjoinedData = google.visualization.data.join(joinedDataを、 、[[0、0]]、range(1、index + 1)、[1]); loader.jsに関する情報は非常に便利です。 –

関連する問題