Javascript 谷歌脚本基于时间的触发器->;一直在请求授权
所以我有一个谷歌脚本功能,可以从谷歌电子表格中读取信息,并发送一封包含数据的电子邮件。我设置了一个基于时间的触发器,它每天在某个小时激活,但问题是每次它触发脚本时都会请求授权,所以基本上我收到的是带有此“基于时间”错误的电子邮件,该错误请求授权 当我手动执行并亲自确认授权时,该函数自身工作正常 我通过代码和脚本的触发器选项设置了基于时间的触发器,但它们似乎都不起作用Javascript 谷歌脚本基于时间的触发器->;一直在请求授权,javascript,google-apps-script,triggers,Javascript,Google Apps Script,Triggers,所以我有一个谷歌脚本功能,可以从谷歌电子表格中读取信息,并发送一封包含数据的电子邮件。我设置了一个基于时间的触发器,它每天在某个小时激活,但问题是每次它触发脚本时都会请求授权,所以基本上我收到的是带有此“基于时间”错误的电子邮件,该错误请求授权 当我手动执行并亲自确认授权时,该函数自身工作正常 我通过代码和脚本的触发器选项设置了基于时间的触发器,但它们似乎都不起作用 你们知道一种方法可以一直保持授权,这样触发器就可以工作并发送带有数据的电子邮件吗?所以要在这里添加一些附加信息,我现在使用的代码是
你们知道一种方法可以一直保持授权,这样触发器就可以工作并发送带有数据的电子邮件吗?所以要在这里添加一些附加信息,我现在使用的代码是: 电子表格由两个人共享,我和一个同事 如果我手动执行此脚本,它将请求授权,然后向我的电子邮件发送我需要的数据。当我试图设置一个触发器来自动执行这个脚本时,我的问题出现了。每次触发器执行脚本时,我都会收到一封电子邮件,说它需要授权 功能:emailCarts
错误消息:执行此操作需要授权。激活:基于时间
function emailCharts(sheet,emails,emailSubject){
var ss = SpreadsheetApp.openById("SPREADSHEET_ID");
var sheet = SpreadsheetApp.openById("SPREADSHEET_ID").getSheetByName("Graficos");
var emailSubject = 'Reporte Automático Reclamos y Sugerencias ' + Utilities.formatDate(sheet.getRange("B2").getValue(),ss.getSpreadsheetTimeZone(),"dd/MM/yy");
var emails = 'MY_EMAIL'; // your email ID
var charts = sheet.getCharts();
var sheet2 = SpreadsheetApp.openById("SPREADSHEET_ID").getSheetByName("Tabla");
var schedRange = sheet2.getDataRange();
var body = '<div style="text-align:left;display: inline-block;font-family:
arial,sans,sans-serif">'
body += '<H1>'+ 'Reclamos Abiertos ' +'</H1>';
body += getHtmlTable(schedRange);
body += '</div><br>';
debugger;
if(charts.length==0){
MailApp.sendEmail({to: emails,subject: "ERROR:"+emailSubject,htmlBody: "No hay
gráficos en el spreadsheet"});
return;
}
var chartBlobs = new Array(charts.length);
var emailBody = "Estimados,<br><br> Junto con saludar, se hace envío del reporte
automático de los Reclamos/Sugerencias/Felicitaciones Abiertos y Cerrados,
correspondiente a la fecha: "
+ Utilities.formatDate(sheet.getRange("B2").getValue(),ss.getSpreadsheetTimeZone(),"dd/MM/yy");
var emailImages = {};
for(var i=0;i<charts.length;i++){
var builder = charts[i].modify();
builder.setOption('vAxis.format', '#');
var newchart = builder.build();
chartBlobs[i] = newchart.getAs('image/png');
emailBody = emailBody + "<p align='center'><img src='cid:chart"+i+"'></p>";
emailImages["chart"+i]= chartBlobs[i];
}
for (var i = 0; i < emails.length; i++){
MailApp.sendEmail({to: emails[i], subject: emailSubject, htmlBody: emailBody+body, inlineImages: emailImages});
}
}
function getHtmlTable(range){
var ss = range.getSheet().getParent();
var sheet = range.getSheet();
startRow = range.getRow();
startCol = range.getColumn();
lastRow = range.getLastRow();
lastCol = range.getLastColumn();
// Read table contents
var data = range.getValues();
// Get css style attributes from range
var fontColors = range.getFontColors();
var backgrounds = range.getBackgrounds();
var fontFamilies = range.getFontFamilies();
var fontSizes = range.getFontSizes();
var fontLines = range.getFontLines();
var fontWeights = range.getFontWeights();
var horizontalAlignments = range.getHorizontalAlignments();
var verticalAlignments = range.getVerticalAlignments();
// Get column widths in pixels
var colWidths = [];
for (var col=startCol; col<=lastCol; col++) {
colWidths.push(sheet.getColumnWidth(col));
}
// Get Row heights in pixels
var rowHeights = [];
for (var row=startRow; row<=lastRow; row++) {
rowHeights.push(sheet.getRowHeight(row));
}
// Future consideration...
var numberFormats = range.getNumberFormats();
// Build HTML Table, with inline styling for each cell
var tableFormat = 'style="border:1.5px solid black;border-collapse:collapse;text- align:center" border = 1.5 cellpadding = 5';
var html = ['<table '+tableFormat+'>'];
// Column widths appear outside of table rows
for (col=0;col<colWidths.length;col++) {
html.push('<col width="'+colWidths[col]+'">')
}
// Populate rows
for (row=0;row<data.length;row++) {
html.push('<tr height="'+rowHeights[row]+'">');
for (col=0;col<data[row].length;col++) {
// Get formatted data
var cellText = data[row][col];
if (cellText instanceof Date) {
cellText = Utilities.formatDate(
cellText,
ss.getSpreadsheetTimeZone(),
"dd/MM/yy");
}
var style = 'style="'
+ 'color: ' + fontColors[row][col]+'; '
+ 'font-family: ' + fontFamilies[row][col]+'; '
+ 'font-size: ' + fontSizes[row][col]+'; '
+ 'font-weight: ' + fontWeights[row][col]+'; '
+ 'background-color: ' + backgrounds[row][col]+'; '
+ 'text-align: ' + horizontalAlignments[row][col]+'; '
+ 'vertical-align: ' + verticalAlignments[row][col]+'; '
+'"';
html.push('<td ' + style + '>'
+cellText
+'</td>');
}
html.push('</tr>');
}
html.push('</table>');
return html.join('');
}
功能电子邮件图表(工作表、电子邮件、电子邮件主题){
var ss=电子表格应用程序openById(“电子表格ID”);
var sheet=SpreadsheetApp.openById(“电子表格ID”).getSheetByName(“Graficos”);
var emailSubject='Reporte Automático Reclamos y Sugerencias'+Utilities.formatDate(sheet.getRange(“B2”).getValue()、ss.getSpreadsheetTimeZone()、“dd/MM/yy”);
var emails='MY_EMAIL';//您的电子邮件ID
var charts=sheet.getCharts();
var sheet2=SpreadsheetApp.openById(“电子表格ID”).getSheetByName(“Tabla”);
var schedRange=sheet2.getDataRange();
变量体=“”
身体+=''''+'Reclamos Abiertos'+'';
body+=getHtmlTable(schedRange);
正文+='
';
调试器;
if(charts.length==0){
sendmail({to:emails,subject:“错误:”+emailSubject,htmlBody:“没有”
gráficos en el电子表格“});
返回;
}
var chartBlobs=新数组(charts.length);
var emailBody=“Estimados,
Junto con saludar,报告环境
雷克拉莫斯/苏格伦西亚/费利西塔奇奥尼斯·阿比尔托斯和塞拉多,
对应人a la fecha:“
+实用程序.formatDate(sheet.getRange(“B2”).getValue(),ss.getSpreadsheetTimeZone(),“dd/MM/yy”);
var emailImages={};
对于(var i=0;i这里是函数?Hi Ricks!请添加更多详细信息,即代码,以显示您正在尝试执行的操作。