EmbeddedChart 不是类图表的一部分
根据Charts 的文档说creates a basic data table, populates an area chart with the data, and adds it into a web page as an image。您还可以获取图像 URL 和 Blob。
作为一种解决方法
通过使用表格
我会使用使用 Charts 提供的 URL 的insertImage函数。
function myFunction() {
var data = Charts.newDataTable()
.addColumn(Charts.ColumnType.STRING, "Year")
.addColumn(Charts.ColumnType.NUMBER, "Sales")
.addColumn(Charts.ColumnType.NUMBER, "Expenses")
.addRow(["2004", 1000, 400])
.addRow(["2005", 1170, 460])
.addRow(["2006", 660, 1120])
.addRow(["2007", 1030, 540])
.addRow(["2008", 800, 600])
.addRow(["2009", 943, 678])
.addRow(["2010", 1020, 550])
.addRow(["2011", 910, 700])
.addRow(["2012", 1230, 840])
.build();
var chart = Charts.newColumnChart()
.setTitle('Sales & Expenses')
.setXAxisTitle('Year')
.setYAxisTitle('Amount (USD)')
.setDimensions(600, 500)
.setDataTable(data)
.build();
var htmlOutput = HtmlService.createHtmlOutput().setTitle('My Chart');
var imageData = Utilities.base64Encode(chart.getAs('image/png').getBytes());
var imageUrl = "data:image/png;base64," + encodeURI(imageData);
// Insert the image in the A1
SpreadsheetApp.getActiveSheet().insertImage(imageUrl, 1, 1);
}
通过使用文档
我会使用insertInlineImage
function myFunction() {
var data = Charts.newDataTable()
.addColumn(Charts.ColumnType.STRING, "Year")
.addColumn(Charts.ColumnType.NUMBER, "Sales")
.addColumn(Charts.ColumnType.NUMBER, "Expenses")
.addRow(["2004", 1000, 400])
.addRow(["2005", 1170, 460])
.addRow(["2006", 660, 1120])
.addRow(["2007", 1030, 540])
.addRow(["2008", 800, 600])
.addRow(["2009", 943, 678])
.addRow(["2010", 1020, 550])
.addRow(["2011", 910, 700])
.addRow(["2012", 1230, 840])
.build();
var chart = Charts.newColumnChart()
.setTitle('Sales & Expenses')
.setXAxisTitle('Year')
.setYAxisTitle('Amount (USD)')
.setDimensions(600, 500)
.setDataTable(data)
.build();
var image = chart.getAs('image/png')
// Insert an image chart
var doc = DocumentApp.getActiveDocument();
var cursor = doc.getCursor();
if (cursor) {
cursor.insertInlineImage(image);
} else {
doc.getBody().insertImage(0, image);
}
}
参考
Google Apps 脚本 > 图表