从谷歌电子表格发送电子邮件

时间:2012-10-17 18:03:06

标签: forms submit google-apps-script

我找到了以下脚本,将表单提交值插入到Google电子表格中。

function doPost(e) { // change to doPost(e) if you are recieving POST data
  var ss = SpreadsheetApp.openById(ScriptProperties.getProperty('active'));
  var sheet = ss.getSheetByName("DATA");
  var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues()[0]; //read headers
  var headers2 = sheet.getRange(2, 1, 1, sheet.getLastColumn()).getValues()[0]; //read headers  
  var nextRow = sheet.getLastRow(); // get next row
  var cell = sheet.getRange('a1');
  var col = 0;
  for (i in headers2){ // loop through the headers and if a parameter name matches the header name insert the value
    if (headers2[i] == "Timestamp"){
      val = new Date();
    } else {
      val = e.parameter[headers2[i]]; 
    }
    cell.offset(nextRow, col).setValue(val);
    col++;
  }
  //http://www.google.com/support/forum/p/apps-script/thread?tid=04d9d3d4922b8bfb&hl=en
  var app = UiApp.createApplication(); // included this part for debugging so you can see what data is coming in
  var panel = app.createVerticalPanel();
  for( p in e.parameters){
    panel.add(app.createLabel(p +" "+e.parameters[p]));
  }
  app.add(panel);
  return app;
}
//http://www.google.sc/support/forum/p/apps-script/thread?tid=345591f349a25cb4&hl=en
function setUp() {
  ScriptProperties.setProperty('active', SpreadsheetApp.getActiveSpreadsheet().getId());
}

现在我想在每次插入一行时向我的两个同事发送格式化的电子邮件。我试着用:

    var emailAddress = "email@gmail.com";  // First column
    var message = "message";       // Second column
    var subject = "Sending emails from a Spreadsheet";
    MailApp.sendEmail(emailAddress, subject, message);

但它没有发送任何东西..任何人都可以提出建议吗?

1 个答案:

答案 0 :(得分:0)

我遇到了同样的麻烦。

使用最新版本的Google Apps,我必须保存脚本,创建新版本,然后重新发布脚本,确保选择新版本。在此之后,新代码生效。我浪费了几个小时,相信如果我保存它就会更新脚本。

不知何故,新方法将脚本保存在别处。除非您完成保存修订和重新发布的过程,否则几乎无法确定实际运行的代码。