首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >应用程序脚本-在电子邮件中以HTML格式发送筛选过的表

应用程序脚本-在电子邮件中以HTML格式发送筛选过的表
EN

Stack Overflow用户
提问于 2017-11-18 17:46:19
回答 2查看 2.5K关注 0票数 0

应用程序脚本新手...

我正试着在电子邮件中以HTML格式发送一个日程表(表格)。

我设法拼凑了一个脚本,它能做我想做的事情……多半是。

如果我使用以下范围,则脚本可以工作。(这是经过过滤的可视表格,其中结果恰好位于前26行)

代码语言:javascript
复制
var schedRange = sheet.getRange("A1:J26");

问题是,完整的表是"A1:J261",当我使用完整的表范围(这样我就可以过滤其他条件)时,我得到:

代码语言:javascript
复制
Limit Exceeded: Email Body Size.

是否可以仅指定筛选的表,而不包括所有隐藏内容?

我的最终目标是能够:

  1. 循环通过第J列的可用条件,但有一些例外
    • (尚未在此列上启动

  1. 对于每个条件,在电子邮件中以超文本标记语言发送表格。

我已经提供了一个公共版本的here

非常感谢您的帮助!

提前谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-06-01 07:38:10

为了避免仅发送可见的行,我在原始数据表中设置了一个查询,这依赖于具有数据验证功能的单元设置。(本质上是一个过滤器)

现在,我的表只包含我想要过滤的内容,而不是对整个表运行过滤器。(所以没有隐藏的行)

该查询如下所示:

代码语言:javascript
复制
=QUERY(DATA!A1:J,"select A, C, D, E, F, G, H, I where J = '"&E1&"'",+1)

其中,E1是我要通过电子邮件发送的公司,查询结果是我要发送给他们的表。

以下是我在过去几个月中一直使用的脚本,用于在Gmail电子邮件中从Google Sheets向每个公司发送预订电子邮件(以HTML表的形式)。

我找不到/回忆不同的代码片段是从哪里来的,所以很抱歉没有提到任何对这个函数有贡献的作者。

这对我来说是一种款待,所以希望所有这些都能帮助到你!

代码语言:javascript
复制
function sendEmail_draft() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = ss.getActiveSheet();
  var Avals = ss.getRange("A1:A").getValues();
  var Alast = Avals.filter(String).length+1;
  var recipient = sheet.getRange("B1").getValue(); // "TO" email address
  var name = SpreadsheetApp.getActiveSpreadsheet().getName();
  var subject = "DRAFT Booking - "+ sheet.getRange("E1").getValue()+ " ";
  subject +=  Utilities.formatDate(
                  sheet.getRange("D1").getValue(),
                  ss.getSpreadsheetTimeZone(),
                  "EEE, MMM d yyyy"),
                  sheet.getRange("D1").getValue()
  var schedRange = sheet.getRange("A3:H"+Alast); 

  // 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>'+ "COMPANY NAME "+ sheet.getRange("E1").getValue() +'</H1>';
  body += '<H2>'+ "WORKBOOK NAME:- "+ name +'</H2>';
  body += '<H2>'+ "Date of Booking - "
        + Utilities.formatDate(
            sheet.getRange("D1").getValue(),
            ss.getSpreadsheetTimeZone(),
            "EEEEE, MMMMM d, yyyy")
        + '</H2>';
  body += getHtmlTable(schedRange);
  body += '</div>';
  debugger;

  //recipient = Session.getActiveUser().getEmail();  // 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));
  }

  // Future consideration...
  var numberFormats = range.getNumberFormats();

  // Build HTML Table, with inline styling for each cell
  var tableFormat = 'style="border:1px solid black;border-collapse:collapse;text-align:center" border = 1 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(),
          'EEE, MMM dd YY'); ///          'EEE, MMM dd - h:mm a');
      }
      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('');
}
票数 2
EN

Stack Overflow用户

发布于 2017-11-20 01:46:52

您正在达到定义的限制。这是在Current limitations中提到的

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47364627

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档