2017-12-20 22 views
1

私は、Tabletop.jsを使用してGoogleシート(json)からデータを取得してプロットしてヒートマップチャートをプロットしようとしています。 私はこれまで、Googleseetのデータをjsonとしてプルしてコンソールに表示するようにしました。しかし、それをヒートマップとして表示するのは面倒です。どんな助けでも大歓迎です。Tabletop.jsを使用してGoogleシートからデータをプルームヒートマップチャートにプルするにはどうすればよいですか?

var publicSpreadsheetUrl = 'https://docs.google.com/spreadsheets/d/1BFPjROVypCGNeLxhk5_PW6PoOb4FDzJsL3DEOEdW_Rc/edit?usp=sharing'; 
 

 
function init() { 
 
    Tabletop.init({ 
 
    key: publicSpreadsheetUrl, 
 
    callback: showInfo, 
 
    simpleSheet: true 
 
    }) 
 
} 
 

 
function showInfo(data, tabletop) { 
 
    console.log(data); 
 
} 
 

 
window.addEventListener('DOMContentLoaded', init) 
 

 
var data = [{ 
 
    graphdata, 
 
    type: 'heatmap' 
 
}]; 
 

 
Plotly.newPlot('myDiv', data1);

+0

あなたの軸は何ですか?年と月?あなたの値はコラム「PE比率」から取られていますか? –

+0

@MaximilianPeters x軸は月、y軸は年を表します。 pe値はz値です。 – Ted

+0

ごめんなさい@AntonioNarkevich。私は他の組み合わせを使って私の側から試していた。とにかく私はそのシートを凍らせます。 – Ted

答えて

0

Plotlyのヒートマップは、Z値のための二次元アレイ(yが最初のインデックスされ、x 2)を必要とします。 tabletopはJSONを返すので、配列に解析する必要があります。

var publicSpreadsheetUrl = 'https://docs.google.com/spreadsheets/d/1BFPjROVypCGNeLxhk5_PW6PoOb4FDzJsL3DEOEdW_Rc/edit?usp=sharing'; 
 

 
function init() { 
 
    Tabletop.init({ 
 
    key: publicSpreadsheetUrl, 
 
    callback: showPlot, 
 
    simpleSheet: true 
 
    }) 
 
} 
 

 
function showPlot(data, tabletop) { 
 
    var xValues = []; //all the values which are shown on the x-axis 
 
    var yValues = []; //all the values which are shown on the y-axis 
 

 
    //get all possible x and y-values 
 
    for (var i = 0; i < data.length; i++) { 
 
    if (xValues.indexOf(data[i].x) === -1) { 
 
     xValues.push(data[i].x); 
 
    } 
 
    if (yValues.indexOf(data[i].y) === -1) { 
 
     yValues.push(data[i].y); 
 
    } 
 
    } 
 
    
 
    //create an empty array for all possible z-values based on the dimensions of x and y 
 
    var zValues = new Array(yValues.length).fill(0).map(row => new Array(xValues.length).fill(0)); 
 

 
    var x = 0; 
 
    var y = 0; 
 

 
    for (i = 0; i < data.length; i++) { 
 
    x = xValues.indexOf(data[i].x); 
 
    y = yValues.indexOf(data[i].y); 
 
    if (x !== -1 && y !== -1) { 
 
     zValues[y][x] = parseFloat(data[i].z); 
 
    } 
 
    } 
 

 
    //the data which is passed to Plotly 
 
    var plotlyData = [{ 
 
    x: xValues, 
 
    y: yValues, 
 
    z: zValues, 
 
    type: 'heatmap' 
 
    }]; 
 
    
 
    //finally draw the plot 
 
    Plotly.plot('myPlot', plotlyData); 
 
} 
 

 
init()
<script src="https://cdnjs.cloudflare.com/ajax/libs/tabletop.js/1.5.1/tabletop.min.js"></script> 
 
<script src="https://cdn.plot.ly/plotly-latest.min.js"></script> 
 
<div id="myPlot"></div>

+0

非常に非常に多くのありがとう。あなたは私の日を救った! – Ted

0

私のコメントを参照してください。データを必要な形式に変換する方法について説明しました。 私はそれをするためにロダッシュを使用しました。

var publicSpreadsheetUrl = 'https://docs.google.com/spreadsheets/d/1BFPjROVypCGNeLxhk5_PW6PoOb4FDzJsL3DEOEdW_Rc/edit?usp=sharing'; 
 

 
    function init() { 
 
     Tabletop.init({ 
 
      key: publicSpreadsheetUrl, 
 
      callback: showInfo, 
 
      simpleSheet: true 
 
     }) 
 
    } 
 

 
    function showInfo(data, tabletop) { 
 
     if (!data || !data.length) { 
 
      throw new Error('Unable to get any data from the spreadsheet'); 
 
     } 
 

 
     // First we wanna parse some values 
 
     var parsed = data.map(val => { 
 
      return {month: val.x, year: parseInt(val.y), z: parseFloat(val.z)}; 
 
     }); 
 

 

 
     // I'm going to hardcode the months here as we wanna keep the order. 
 
     // You minght consider using something like moment.js to get month names. 
 
     var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']; 
 

 
     var minYear = _.minBy(parsed, p => p.year); 
 
     var maxYear = _.maxBy(parsed, p => p.year); 
 

 
     // Create the range of years. This is going to be our Y axis. 
 
     var years = _.range(minYear.year, maxYear.year); 
 

 
     // No wa are going to iterrate over months and years, searching for values. 
 
     // By doing this we're going to end up with the data format accepted by plotly. 
 
     // https://plot.ly/javascript/heatmaps/#heatmap-with-categorical-axis-labels 
 
     var zValues = _.map(months, m => { 
 
      return _.map(years, y => { 
 
       var matchingElement = _.find(parsed, p => p.year === y && p.month === m); 
 
       if (matchingElement) { 
 
        return matchingElement.z; 
 
       } 
 
       // If we haven't found the value fill it with null. 
 
       return null; 
 
      }) 
 
     }) 
 

 
     var chartData = [{ 
 
      z: zValues, x: months, y: years, 
 
      type: 'heatmap' 
 
     }]; 
 

 
     Plotly.newPlot('myDiv', chartData); 
 
    } 
 

 
    window.addEventListener('DOMContentLoaded', init)
<div id="myDiv"></div> 
 

 
<script src='https://cdnjs.cloudflare.com/ajax/libs/tabletop.js/1.5.1/tabletop.min.js'></script> 
 
<script src='https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.4/lodash.js'></script> 
 

 
<!-- Latest compiled and minified plotly.js JavaScript --> 
 
<script type="text/javascript" src="https://cdn.plot.ly/plotly-latest.min.js"></script>

+0

同じ問題を解決する2つの異なるアプローチ:) –

+0

ありがとう@Antonio。コードには、いくつかのタッチアップが必要です。私はこれを世話することができます...もう一度感謝します。 – Ted

+0

@Ted喜んで:) –

関連する問題