Google Script Time-Based Trigger -> Постоянный запрос авторизации - PullRequest
0 голосов
/ 29 августа 2018

Итак, у меня есть функция скрипта Google, которая считывает информацию из электронной таблицы Google и отправляет электронное письмо с данными. Я настроил основанный на времени триггер, который активируется каждый день в определенный час, но проблема в том, что каждый раз, когда он запускает, скрипт запрашивает авторизацию, поэтому в основном я получаю электронное письмо с этой «временной» ошибкой, которая запрашивает для авторизации.

Функция работает самостоятельно, когда я выполняю ее вручную и сам подтверждаю авторизацию.

Я установил основанный на времени триггер с помощью кода и опцию триггера сценариев, но ни один из них, похоже, не работает.

Ребята, знаете ли вы, как всегда поддерживать авторизацию, чтобы триггер мог работать и отправлять электронное письмо с данными?

1 Ответ

0 голосов
/ 30 августа 2018

поэтому, чтобы добавить сюда дополнительную информацию, это код, который я сейчас использую:

Электронная таблица распределяется между двумя людьми, мной и коллегой.

Если я выполню этот скрипт вручную, он запросит авторизацию, а затем отправит на мой электронный адрес необходимые мне данные. Моя проблема возникает, когда я пытался настроить триггер для автоматического выполнения этого сценария. Каждый раз, когда триггер запускает скрипт, я получаю электронное письмо, в котором говорится, что ему нужна авторизация.

Функция: 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('');
 }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...