当我在Col“I”(电子邮件)中输入任何内容时,我正在使用此脚本自动将时间戳添加到Col“J”(电子日期)中,并且效果非常好:
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”和“Phoned”列(将时间戳添加到“P-Date”)。除此之外,对于 ONLY “电子邮件”和“短信”列,如果该单元格以前为空,则必须仅添加/更新日期。
谢谢!
答案 0 :(得分: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按钮)。