Google apps script 如何用谷歌脚本在电子邮件中发送表格?
我一直在尝试创建一个脚本,将一个单元格数组作为一个表发送(保留格式),但是在几个小时后,大约30个版本的代码测试后,我不断遇到一堵墙 到目前为止,我: 1.收到一封空邮件 2.获取一封包含我所有数据但没有格式的电子邮件(所有数字一个接一个,而不是表格) 3.在电子邮件中以HTML代码形式编写的表,而不是表本身。 4.写有[对象]作为消息的电子邮件 我使用以下代码得到结果2:Google apps script 如何用谷歌脚本在电子邮件中发送表格?,google-apps-script,google-sheets,gmail,Google Apps Script,Google Sheets,Gmail,我一直在尝试创建一个脚本,将一个单元格数组作为一个表发送(保留格式),但是在几个小时后,大约30个版本的代码测试后,我不断遇到一堵墙 到目前为止,我: 1.收到一封空邮件 2.获取一封包含我所有数据但没有格式的电子邮件(所有数字一个接一个,而不是表格) 3.在电子邮件中以HTML代码形式编写的表,而不是表本身。 4.写有[对象]作为消息的电子邮件 我使用以下代码得到结果2: var conv = SheetConverter.init(ss.getSpreadsheetTimeZone(),
var conv = SheetConverter.init(ss.getSpreadsheetTimeZone(),
ss.getSpreadsheetLocale());
var html = conv.convertRange2html(dataRange);
最后,我的最后一次尝试再次失败,但似乎很有希望,是在下面。我认为,我目前的问题是sendEmail函数没有调用其上的getHtmlTable:
function getHtmlTable(range){
var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Sheet1");
startRow = "6";
startCol = "B";
lastRow = "18";
lastCol = "E";
// Read table contents
var dataRange = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Sheet1").getRange("B6:E18");
var data = dataRange.getValues();
// Get css style attributes from range
var fontColors = dataRange.getFontColors();
var backgrounds = dataRange.getBackgrounds();
var fontFamilies = dataRange.getFontFamilies();
var fontSizes = dataRange.getFontSizes();
var fontLines = dataRange.getFontLines();
var fontWeights = dataRange.getFontWeights();
var horizontalAlignments = dataRange.getHorizontalAlignments();
var verticalAlignments = dataRange.getVerticalAlignments();
// Get column widths in pixels
var colWidths = ["10"];
// Get Row heights in pixels
var rowHeights = ["10"];
// Future consideration...
var numberFormats = dataRange.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('');
}
function sendEmail() {
// Fetch email address
var emailRange = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Sheet1").getRange("B1");
var emailAddress = emailRange.getValues();
// Send Email.
var message = getHtmlTable;
var subject = 'Test 34';
MailApp.sendEmail(emailAddress, subject, message);
}
函数getHtmlTable(范围){
var sheet=SpreadsheetApp.getActiveSpreadsheet().getSheetByName(“Sheet1”);
startRow=“6”;
startCol=“B”;
lastRow=“18”;
lastCol=“E”;
//阅读表格内容
var dataRange=SpreadsheetApp.getActiveSpreadsheet().getSheetByName(“Sheet1”).getRange(“B6:E18”);
var data=dataRange.getValues();
//从范围中获取css样式属性
var fontColors=dataRange.getFontColors();
var backgrounds=dataRange.getBackgrounds();
var fontFamilies=dataRange.getFontFamilies();
var fontSizes=dataRange.getFontSizes();
var fontLines=dataRange.getFontLines();
var fontWeights=dataRange.getFontWeights();
var horizontalAlignments=dataRange.getHorizontalAlignments();
var verticalAlignments=dataRange.getVerticalAlignments();
//获取以像素为单位的列宽
var colWidths=[“10”];
//获取以像素为单位的行高度
var rowHeights=[“10”];
//未来考虑。。。
var numberFormats=dataRange.getNumberFormats();
//构建HTML表格,为每个单元格设置内联样式
var tableFormat='style=“border:1px纯黑色;边框折叠:折叠;文本对齐:居中”边框=1单元格填充=5';
var html=[''];
//列宽显示在表行之外
对于(col=0;col而不是将html代码放入数组中,将新字符串连接到同一变量中。此外,使用
htmlbody
作为电子邮件正文。请注意for
循环中的变量表
:
function createTable(data){
var cells = [];
//This would be the header of the table
var table = "<html><body><br><table border=1><tr><th>Column A</th><th>Column B</th><th>Column C</th><th>Column D</th><th>Column E</tr></br>";
//the body of the table is build in 2D (two foor loops)
for (var i = 0; i < data.length; i++){
cells = data[i]; //puts each cell in an array position
table = table + "<tr></tr>";
for (var u = 0; u < cells.length; u++){
table = table + "<td>"+ cells[u] +"</td>";
}
}
table=table+"</table></body></html>";
//Send the email:
MailApp.sendEmail({
to: "example@mail.com",
subject: "Example",
htmlBody: table});
}
函数createTable(数据){
var单元格=[];
//这将是表的标题
var table=“
列A列B列C列D列E”;
//表格主体以2D形式构建(两个foor循环)
对于(变量i=0;i
有关MailApp和htmlbody的更多信息。欢迎来到StackOverflow!请阅读有关“”和“”的信息。这将使其他人更容易帮助您。我找到了一种更好的方法,但是我仍然存在格式问题。代码现在如下图所示,但我找不到如何使单元格的背景和数字的格式根据工作表中每个单元格的格式而有所不同: