Google apps script 在谷歌表单上发送基于触发器的电子邮件,给出一些我不理解的随机结果

Google apps script 在谷歌表单上发送基于触发器的电子邮件,给出一些我不理解的随机结果,google-apps-script,google-sheets,google-workspace,Google Apps Script,Google Sheets,Google Workspace,我一直在尝试制作一个脚本,可以通过电子邮件发送一系列单元格的电子邮件。虽然发送电子邮件部分工作得很好,但当我添加基于时间的触发器时,它会发送一封我不理解的随机电子邮件 我试着在我的工作表中发送一系列单元格,每天早上9:30自动实时更新给我的老板 function sendEmail() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getActiveSheet(); var range = shee

我一直在尝试制作一个脚本,可以通过电子邮件发送一系列单元格的电子邮件。虽然发送电子邮件部分工作得很好,但当我添加基于时间的触发器时,它会发送一封我不理解的随机电子邮件

我试着在我的工作表中发送一系列单元格,每天早上9:30自动实时更新给我的老板

 function sendEmail() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = ss.getActiveSheet();
  var range = sheet.getDataRange();
  var recipient = 'aaaabalamurali1996@gmail.com'
  var subject = 'NRV Tracker'
  var date = Utilities.formatDate(new Date(), "GMT+1", "dd/MM/yyyy")
  var schedRange = sheet.getRange("A1:Y6"); 
  //var schedRange = sheet.getRange(Col == 3 && compare == date);

  
  var body = '<div style="text-align:center;display: inline-block;font-family: arial,sans,sans-serif">'
  body += '<H1>'+ 'NRV Tracker ' +'</H1>';
  body += '<H2>'
  body += getHtmlTable(schedRange);//change this line
  body += '</div>';
  debugger;

  recipient = 'abc@abc.com';  // For debugging, send only to self
  GmailApp.sendEmail(recipient, subject, "Requires HTML", {htmlBody:body})

  var ts = ss.getSheetByName("D-1 Day");
  var srange = sheet.getRange("A1:Y6");
  var trange = ts.getRange("A1:Y6");
  srange.copyTo(trange, {contentsOnly: true});
}


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();

 
  var colWidths = [];
  for (var col=startCol; col<=lastCol; col++) { 
    colWidths.push(sheet.getColumnWidth(col));
  }

 
  var rowHeights = [];
  for (var row=startRow; row<=lastRow; row++) { 
    rowHeights.push(sheet.getRowHeight(row));
  }

 
  var tableFormat = 'style="font-size: 10px; border:1px solid black;border-collapse:collapse;text-align:center" border = 1 cellpadding = 1';
  var html = ['<table '+tableFormat+'>'];

  // Column widths appear outside of table rows
  for (col=0;col<colWidths.length;col++) {
    html.push('<col width="'+colWidths[col]+'">')
  }

 
  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(),
                     'M/d');
      }
      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('');
}
函数sendmail(){ var ss=SpreadsheetApp.getActiveSpreadsheet(); var sheet=ss.getActiveSheet(); var range=sheet.getDataRange(); var受体aaaabalamurali1996@gmail.com' 变量主题='NRV跟踪器' var date=Utilities.formatDate(新日期(),“GMT+1”,“dd/MM/yyyy”) var schedRange=sheet.getRange(“A1:Y6”); //var schedRange=sheet.getRange(Col==3&&compare==date); 变量体=“” 车身+='''+'NRV跟踪器'+''; 正文+=“” body+=getHtmlTable(schedRange);//更改此行 身体+=''; 调试器; 接受者abc@abc.com“;//对于调试,只发送给self sendmail(收件人,主题,“需要HTML”{htmlBody:body}) 变量ts=ss.getSheetByName(“D-1天”); var srange=sheet.getRange(“A1:Y6”); var trange=ts.getRange(“A1:Y6”); srange.copyTo(trange,{contentsOnly:true}); } 函数getHtmlTable(范围){ var ss=range.getSheet().getParent(); var sheet=range.getSheet(); startRow=range.getRow(); startCol=range.getColumn(); lastRow=range.getLastRow(); lastCol=range.getLastColumn(); //阅读表格内容 var data=range.getValues(); //从范围中获取css样式属性 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(); var冷宽=[];
对于(var col=startCol;col尝试引用希望发送到新工作表的单元格范围,并使用下面的代码以PDF格式发送该工作表。这非常容易实现

//从Google电子表格生成PDF文件并发送到指定的电子邮件地址
函数emailSpreadsheetAsPDF(){
const sheetToPrint=“电子表格名称”;//要打印的工作表的名称
const ss=SpreadsheetApp.getActiveSpreadsheet();//要使用的工作表
const email=SpreadsheetApp.getActiveSpreadsheet().getSheetByName('SHEET NAME').getRange('E3').getValue().toString();//从指定单元格获取电子邮件地址
const subject=`subject-${ss.getName()}`;//电子邮件的主题
const body=“body”;//电子邮件的正文
const shID=ss.getSheetByName(sheetToPrint).getSheetId();//工作表的ID
常量url=https://docs.google.com/spreadsheets/d/SS_ID/export?'.replace('SS_ID',SS.getId());//电子表格的url
常量导出选项=
'exportFormat=pdf&format=pdf'+//导出为pdf/csv/xls/xlsx
'&size=A4'+//PDF的大小(legal/A4/letter)
“&trait=true”+//PDF的方向(横向为false)
“&fitw=true”+//适合页面宽度(实际大小为false)
'&sheetnames=false&printtitle=false'+//隐藏可选的页眉和页脚
“&pagenumbers=false&gridlines=false”+//隐藏页码和网格线
'&fzr=false'+//不要在每页上重复行标题(冻结行)
“&gid=”+shID;//工作表的Id
var params={method:“GET”,头:{“authorization”:“Bearer”+ScriptApp.getOAuthToken()};
//生成PDF文件
var response=UrlFetchApp.fetch(url+exportOptions,params).getBlob();
//将带有指定正文文本和附加PDF文件的电子邮件发送到指定地址
GmailApp.sendmail(电子邮件、主题、正文、{
htmlBody:body,
附件:[{
文件名:`FILE NAME-${ss.getName()}`+.pdf“,
内容:response.getBytes(),
mimeType:“应用程序/pdf”
}]
});
}
您只需更改
电子表格名称
工作表名称
主题
正文
,以及
文件名
。更改
导出选项
也可能对您有所帮助

一旦你实现了这个,只需设置一个触发器,让它每天早上9点运行


如果您有任何问题,请随时与我联系。

您应该通过HtmlService传递您的html表。我怎么做?我是新来的,如果您能详细说明的话,我想可能是greatI think
body+=HtmlService.createHtmlOutput(getHtmlTable(schedRange))
我在代码更改行旁边添加了一条注释。嘿,我尝试过你的编辑。我收到了这封电子邮件。-我收到了这封电子邮件。你在电子邮件声明中遗漏了一条引语。希望你不介意我更改它。顺便说一句,我一直在寻找文档中解释这一点的地方,因为我想了解我这并不更好,但它似乎只存在于github等网站中。@Cooper你的眼光很好!谢谢你的编辑。@Cooper你一直在寻找什么?我不太理解你的第二条评论。@Cooper别担心,如果可以的话,我很乐意帮你。不过,我不完全确定我是从哪里学来的。这是一个拼凑的项目。Wh但我可以告诉你的是,我真的很喜欢(并且更喜欢)fetchApp方法,因为它为各种转换(xlsx、pdf、csv等)提供了很多易于使用的选项,当然还有exportOptions。在前面的一个线程()中有更多关于它的信息。