我一直在努力创建具有智能范围的图表,这在谷歌电子表格中的数据更新时会有所不同。但是我成功了,我无法使.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());
}
}
}
}
答案 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”行开始。它获取一行数据,以及列数如何。