Google电子表格脚本中图表的命名范围问题

时间:2015-03-05 15:41:27

标签: charts google-apps-script google-sheets

我一直在努力创建具有智能范围的图表,这在谷歌电子表格中的数据更新时会有所不同。但是我成功了,我无法使.setOption方面起作用。我想要例如,图表的标题,描述等。但这不是主要问题,因为我可以手工插入。

更重要的是范围名称,因为我没有使用脚本。因此,在图表中,不可能看到每列代表什么,我真的想解决这个问题。我试图使用.setNamedRange()方面,但这不起作用。

有人可以帮助我吗?

function check() {

 var sheet = SpreadsheetApp.getActiveSheet();
    var end = sheet.getLastRow();
    var start = (end - 5); 
    var endnew = (end - 4);
    var startnew = (end - 6);

     if(sheet.getCharts().length == 0){    
     Logger.log("Er is geen grafiek");
     var chartBuilder = sheet.newChart()
     .asColumnChart().setStacked()
     .addRange(sheet.getRange("A" + startnew + ":" + "A" + endnew)) // should have a name
     .addRange(sheet.getRange("B" + startnew + ":" + "B" + endnew)) // should have a name
     .addRange(sheet.getRange("E" + startnew + ":" + "E" + endnew)) //should have a name
     .setOption('title', 'Effectief gebruik kantoorruimte') //not working
     .setPosition(10, 10, 0, 0)

     var chart = chartBuilder.build();
     sheet.insertChart(chart);    
  }

  else{
Logger.log("Er is wel een grafiek");
var charts = sheet.getCharts();
for (var i in charts) {
  var chart = charts[i];
  var ranges = chart.getRanges();
  var builder = chart.modify();
  for (var j in ranges) {
    var range = ranges[j];
    builder.removeRange(range);

    builder
    .addRange(sheet.getRange("A" + (start) + ":" + "A" + end)) //should have a name
    .addRange(sheet.getRange("B" + (start) + ":" + "B" + end)) //should have a name
    .addRange(sheet.getRange("E" + (start) + ":" + "E" + end))  // should have a name
    .setOption('title', 'Effectief gebruik kantoorruimte')
    .build();
    sheet.updateChart(builder.build());  

   }
    }
  }

}

1 个答案:

答案 0 :(得分:0)

我假设这个代码是问题吗?

builder
.addRange(sheet.getRange("A" + (start) + ":" + "A" + end))

也许尝试使用JavaScript toString()方法来确保您的文本公式正常运行。

.addRange(sheet.getRange("A" + start.toString() + ":" + "A" + end.toString()))

您可以使用不同的格式:

getRange(row, column, numRows, numColumns)

所以,它将是:

getRange(start, 1, 1, numColumns)

从A列的“start”行开始。它获取一行数据,以及列数如何。