1

我发现以下脚本将表单提交值插入到谷歌电子表格中。

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);

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

4

1 回答 1

0

我有同样的麻烦。

使用最新版本的 Google Apps,我必须保存脚本、创建新修订版并重新发布脚本,确保选择新修订版。在此之后,新代码生效。我浪费了几个小时,以为只要保存它就会更新脚本。

不知何故,新方法将脚本保存在其他地方。除非您完成保存修订并重新发布的过程,否则几乎不可能知道实际运行的是什么代码。

于 2013-03-02T00:49:52.820 回答