首页 文章

将时间戳脚本扩展到多个列,仅在单元格以前为空时才更新

提问于
浏览
0

我正在使用此脚本自动将时间戳添加到Col“J”(E-Date)中,当任何内容输入Col“I”(电子邮件)时它运行良好:

function onEdit(event)
{ 
  var timezone = "GMT+2";
  var timestamp_format = "MM-dd-yy";
  var updateColName = "Emailed";
  var timeStampColName = "E-Date";
  var sheet = event.source.getActiveSheet();

  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;
  if (dateCol > -1 && index > 1 && editColumn == updateCol) { 
    var cell = sheet.getRange(index, dateCol + 1);
    var date = Utilities.formatDate(new Date(), timezone, timestamp_format);
    cell.setValue(date);
  }
}

这是Google表格的链接,只需向Col "I"(电子邮件)添加任何内容,您就会看到添加的日期 - https://docs.google.com/spreadsheets/d/15_rDiujP-N1nNeFLIjbpVdU3bVZOftC5TdMvqD6EZJ8/edit?usp=sharing

但是,我想扩展这个脚本,以便它也适用于"SMSed"列(将时间戳添加到"S-Date) and the " Phoned " column (adds timestamp to " P-Date“) . 除此之外,对于 ONLY "Emailed"和"SMSed"列,它必须只添加/更新如果单元格先前为空,则为日期 .

谢谢!

1 回答

  • 0

    删除所有的onEdit()脚本并尝试一下

    function onEdit(e) {
    var cols, ind;
    cols = [9, 11, 13];
    ind = cols.indexOf(e.range.columnStart);
    if (ind === -1 || typeof e.value === 'object') return;
    var v = (ind === 0) ? new Date() : (e.range.offset(0, 1).getValue())? null : new Date();
    if (v) e.range.offset(0, 1).setValue(v);
    }
    

    根据需要使用时间戳格式化列(通过电子表格中的123按钮) .

相关问题