您的数组(称为值)是一个二维数组,对应于工作表中的一行,这意味着您必须遍历其第一个元素。我编写了一个小脚本,其中包含一个函数,该函数使用这样的标题和值组成消息:
function test(){
var ss = SpreadsheetApp.getActiveSpreadsheet();
var responses = ss.getSheetByName("Form Responses");
var lastRow = responses.getLastRow();
var values = responses.getRange("A"+(lastRow)+":AK"+(lastRow)).getValues();// get the range and values in one step
var headers = responses.getRange("A1:AK1").getValues();// do the same for headers
var message = composeMessage(headers,values);// call the function with 2 arrays as arguments
Logger.log(message);// check the result and then send the email with message as text body
}
function composeMessage(headers,values){
var message = 'Here are the data :'
for(var c=0;c<values[0].length;++c){
message+='\n'+headers[0][c]+' : '+values[0][c]
}
return message;
}
请注意,您可以使用相同的结构使用 html 表格构建更好看的 html 格式电子邮件(请参阅此处的参考资料)
编辑2
我写了一小段代码,在表格中生成文本和 HTML,随意改进 HTML 格式的颜色等......
function testMail(){
var ss = SpreadsheetApp.getActiveSpreadsheet();
var responses = ss.getSheetByName("Sheet1");
var lastRow = responses.getLastRow();
var values = responses.getRange("A"+(lastRow)+":M"+(lastRow)).getValues();
var headers = responses.getRange("A1:AK1").getValues();
var message = composeMessage(headers,values);
var messageHTML = composeHtmlMsg(headers,values);
Logger.log(messageHTML);
MailApp.sendEmail(Session.getEffectiveUser().getEmail(),'test html', message,{'htmlBody':messageHTML});
}
function composeMessage(headers,values){
var message = 'Here are the data you submitted :\n'
for(var c=0;c<values[0].length;++c){
message+='\n'+headers[0][c]+' : '+values[0][c]
}
return message;
}
function composeHtmlMsg(headers,values){
var message = 'Here are the data you submitted :<br><br><table style="background-color:lightblue;border-collapse:collapse;" border = 1 cellpadding = 5><th>data</th><th>Values</th><tr>'
for(var c=0;c<values[0].length;++c){
message+='<tr><td>'+headers[0][c]+'</td><td>'+values[0][c]+'</td></tr>'
}
return message+'</table>';
}
编辑 3
按照您的评论:这是我的测试表+屏幕截图的日志。检查你的日志,看看你的数据是否有类似的结构。
[13-07-16 14:29:40:920 CEST] Here are the data you submitted :<br><br><table style="background-color:lightblue;border-collapse:collapse;" border = 1 cellpadding = 5><th>data</th><th>Values</th><tr><tr><td>Titre</td><td>Mr</td></tr><tr><td>nom</td><td>Wales</td></tr><tr><td>prénom</td><td>xavier</td></tr><tr><td>adresse</td><td>Sunset Bld, 45678</td></tr><tr><td>code</td><td>5000</td></tr><tr><td>ville</td><td>Los Angeles</td></tr><tr><td>pays</td><td>USA</td></tr><tr><td>email</td><td>john.smith@gmail.com</td></tr><tr><td>tél1</td><td>1212345654345</td></tr><tr><td>tél2</td><td></td></tr><tr><td>Commun</td><td>Théâtre</td></tr><tr><td>GROUPE</td><td>Festival</td></tr><tr><td>organisme</td><td>xxx</td></tr></table>
- “th”是标题标签(在<>之间,这里不能写,因为浏览器不显示)
- “td”是单元格标签(在<>之间,这里不能写,因为浏览器不显示)
- “tr”是“row”标签(在<>之间,这里不能写,因为浏览器不显示)
这些标签中的每一个都必须以 /t... 结束标签(周围有 <>)结束才能有效。正如您在日志数据中看到的那样,脚本中的循环结构会自动处理这一点。
另请注意,我在循环结束时添加了一个表格结束标记......我在我的第一个代码中忘记了它,但它在我的测试中就像那样工作。