请您帮忙了解如何使用Google脚本将图表导出到图片。
我写了这段代码,但它没有用。我担心不推荐使用API getAs 。
function TestEmailCharts(){
var sheet = SpreadsheetApp.getActiveSheet();
var charts = sheet.getCharts();
if(charts.length!=0)
{
var chartBlobs=new Array(charts.length);
var emailBody="Charts<br>";
var emailImages={};
for(var i=0;i<charts.length;i++){
chartBlobs[i]= charts[i].getAs("image/jpeg").setName("chartBlob"+i);
emailBody= emailBody + "<img src='cid:chart"+i+"'><br>";
emailImages["chart"+i]= chartBlobs[i];
}
MailApp.sendEmail({
to: "email@gmail.com",
subject: "test2",
htmlBody: emailBody,
inlineImages:emailImages});
}
}
要重现此问题,请创建Google电子表格 使用一些数据创建一个简单的图表。
将此代码添加到脚本中。 将email@gmail.com替换为您的电子邮件
通常您应该会收到一封包含图表图片的电子邮件 但问题是您将收到一封黑色图像的电子邮件。
祝你好运。
答案 0 :(得分:1)
将Google表格图表导出为图像
通过电子邮件: 首先创建图表,然后获取其斑点。然后将blob作为附件发送。
function createPieChart(){
var sheet = SpreadsheetApp.openById("<ID>").getSheetByName("<SheetName>");
var chartBuilder = sheet.newChart()
.asPieChart()
.set3D()
.addRange(sheet.getRange("A20").getDataRegion())
.setPosition(16, 5, 0, 0)
.setOption('title', "Total hour split in 2020");
var blob = chartBuilder.build().getBlob();
sendMail(blob);
}
function sendMail(img){
MailApp.sendEmail({
to: "john@domain.com",
subject: "test",
htmlBody: "fair enough",
attachments: [img]}); //If this gives you problems, replace img with img.getAs(MimeType.JPEG)
}
到另一个电子表格(与图表的源数据不同):
类似的方法,创建图表,然后将blob作为图像插入目标表中:
function createPieChart(){
var srcSheet = SpreadsheetApp.openById("<ID>").getSheetByName("<SheetName>");
var destSheet = SpreadsheetApp.openById("<ID>").getSheetByName("<SheetName>");
var chartBuilder = srcSheet.newChart()
.asPieChart()
.set3D()
.addRange(sheet.getRange("A20").getDataRegion())
.setPosition(16, 5, 0, 0)
.setOption('title', "Total hour split in 2020");
var blob = chartBuilder.build().getBlob();
destSheet.insertImage(blob, 1, 1);
}