Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/google-apps-script/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
GoogleSheets脚本:带有HTML表格的电子邮件,该表格只有一组_Html_Google Apps Script_Google Sheets - Fatal编程技术网

GoogleSheets脚本:带有HTML表格的电子邮件,该表格只有一组

GoogleSheets脚本:带有HTML表格的电子邮件,该表格只有一组,html,google-apps-script,google-sheets,Html,Google Apps Script,Google Sheets,在谷歌电子表格中,我希望能够发送一封包含HTML表格的电子邮件。我已经完成了下面的工作,现在想进一步扩展功能。现在,我试图理解/找到一种方法,如何基于变量过滤getRange 例如: 如果列C=Todays Date,我希望将所有包含Todays Date的行返回到电子邮件中的HTML表中。我一直在玩GetRange,但当调整它时,它会打破其他范围。我该怎么做呢 function sendEmail() { var ss = SpreadsheetApp.getActiveSpreadshe

在谷歌电子表格中,我希望能够发送一封包含HTML表格的电子邮件。我已经完成了下面的工作,现在想进一步扩展功能。现在,我试图理解/找到一种方法,如何基于变量过滤getRange

例如: 如果列C=Todays Date,我希望将所有包含Todays Date的行返回到电子邮件中的HTML表中。我一直在玩GetRange,但当调整它时,它会打破其他范围。我该怎么做呢

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

  // Put Name & Date into email first.
  // We only want the schedule within borders, so
  // these are handled separately.
  var body = '<div style="text-align:center;display: inline-block;font-family: arial,sans,sans-serif">'
  body += '<H1>'+ 'Deployment Table Header ' +'</H1>';
  body += '<H2>'
  body += getHtmlTable(schedRange);
  body += '</div>';
  debugger;

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

/**
 * Return a string containing an HTML table representation
 * of the given range, preserving style settings.
 */
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));
  }

  // Build HTML Table, with inline styling for each cell
  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]+'">')
  }

  // 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(),
                     '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受体email@gmail.com' var subject='subject' var date=Utilities.formatDate(新日期(),“GMT+1”,“dd/MM/yyyy”) var schedRange=sheet.getRange(“A1:L21”);//试图理解 //var schedRange=sheet.getRange(Col==3&&compare==date); //首先在电子邮件中输入姓名和日期。 //我们只希望时间表在边界内,所以 //这些是分开处理的。 变量体=“” 正文+=''+''部署表标题'+''; 正文+=“” body+=getHtmlTable(schedRange); 身体+=''; 调试器; 接受者email@gmail.com“;//对于调试,只发送给self sendmail(收件人,主题,“需要HTML”{htmlBody:body}) } /** *返回包含HTML表表示形式的字符串 *在给定范围内,保留样式设置。 */ 函数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),您可以在构建HTML表时过滤掉不需要的任何行:

function getHtmlTable(range){

// ... your code...
  var today = new Date();
  for (row=0;row<data.length;row++) {
    var row_date = data[row][2]; // Assuming date is in 3rd column
    if(sameDay(new Date(row_date), today){ // See note
      html.push('<tr height="'+rowHeights[row]+'">');
      for (col=0;col<data[row].length;col++) {

        // ... your code ...
      }
    }
  }
}

function sameDay(d1, d2) {
  return d1.getFullYear() === d2.getFullYear() &&
    d1.getMonth() === d2.getMonth() &&
    d1.getDate() === d2.getDate();
}
函数getHtmlTable(范围){ //…你的代码。。。 var today=新日期();
对于(row=0;row)为什么不简单地在函数中添加条件,在添加行的循环中添加条件,以便在条件不满足时跳过该行格式设置看起来不正确-尝试添加内容,但我收到一个错误t“TypeError:无法从undefined读取属性“length”。(第49行,文件“Code”)“函数getHtmlTable(range){for(row=0;row
data
是您在
getHtmlTable
函数中定义的变量。该错误似乎表明
data
未定义。请确保在定义
var data=range.getValues();