谷歌应用程序脚本甚至没有抓住列标题

时间:2017-05-15 21:11:27

标签: google-apps-script google-sheets

function onEdit(event)
{ 
  var timezone = "GMT-6";
  var timestamp_format = "HH:mm:ss"; // Timestamp Format. 
  var sheet = event.source.getActiveSheet();//Name of the sheet where you want to run this script.
  var actRng = event.source.getActiveRange();
  var editColumn = actRng.getColumn();
  var index = actRng.getRowIndex();
  var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues();
  var dateCol = headers[0].indexOf(timeStampColName);
  var updateCol = headers[0].indexOf(updateColName); updateCol = updateCol+1;
  var updateColName = sheet.getRange( 1, editColumn).getValue ();
  var timeStampColName = "null";

  if (updateColName == "PACK STARTED BY") {timeStampColName = "Pack Start";}

if (dateCol > -1 && index > 1 && editColumn == updateCol) { // only timestamp if 'Last Updated' header exists, but not in the header row itself!
    var cell = sheet.getRange(index, dateCol + 1);
    var date = Utilities.formatDate(new Date(), timezone, timestamp_format);
    cell.setValue(date);
  }
}

以上是我在工作表中运行的代码。现在,此编辑事件应该从当前活动的单元格中获取列标题。然后使用if语句应该将一个静态值放入timestamp列名中,这样我就可以将时间戳放在我的工作表中。我很难调试这个,因为我不知道如何在google脚本编制屏幕上进行编辑调试。所以我不能告诉代码什么是不对的。现在它什么也没做。

0 个答案:

没有答案