javascript - Google Apps 脚本 - 更新时将时间戳添加到多个单元格

标签 javascript google-apps-script

我正在尝试更新 this tutorial 中的代码当我更新单元格时添加时间戳。到目前为止,它适用于第一个单元格,但在将值复制到整个范围时不适用于所有单元格。

有人可以看一下并帮助调整这一点,以便所有单元格都使用时间戳进行更新,而不仅仅是第一个单元格吗?

谢谢!

function onEdit(event)
{ 
  var timezone = "GMT+1";
  var timestamp_format = "dd/MM/yyyy HH:mm:ss"; // Timestamp Format. 
  var updateColName = "Message";
  var timeStampColName = "Timestamp";
  var sheet = event.source.getSheetByName('Sheet1'); //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;
  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);
  }
}

最佳答案

您正在使用getRange(row, column)它检索单个单元格。

当您复制粘贴多个值或下拉单元格时,以下几行仅设置范围中第一个单元格的值:

var cell = sheet.getRange(index, dateCol + 1);

cell.setValue(date);

使用getRange(row, column, numRows)检索包含多行的范围。如果我们将其更改为:

sheet.getRange (index, dateCol + 1, numRows)

它将更改此范围内的所有单元格。

请尝试一下。

function onEdit(event) { 
  var timezone = "GMT+1";
  var timestamp_format = "dd/MM/yyyy HH:mm:ss"; // Timestamp Format. 
  var updateColName = "Message";
  var timeStampColName = "Timestamp";
  var sheet = event.source.getSheetByName('Sheet1'); //Name of the sheet where you want to run this script.    
  var actRng = event.range;
  var editColumn = actRng.getColumn();
  var index = actRng.getRowIndex();
  var numRows = actRng.getNumRows();
  var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues();
  var dateCol = headers[0].indexOf(timeStampColName);
  var updateCol = headers[0].indexOf(updateColName)+1; 
  if (dateCol > -1 && index > 1 && editColumn == updateCol) { 
    var range = sheet.getRange(index, dateCol + 1,numRows);
    var date = Utilities.formatDate(new Date(), timezone, timestamp_format);
    range.setValue(date);
  }
}

引用:

关于javascript - Google Apps 脚本 - 更新时将时间戳添加到多个单元格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68454747/

相关文章:

javascript - CSS 和 Javascript/jQuery - 类似于 Facebook 的可折叠 DIV 部分

javascript - 如何在 Express 中设置 IP 白名单?

javascript - 如何从包含字符串、对象和数组的 Javascript 对象中检索动态指定的、任意的和深度嵌套的值?

google-apps-script - 尝试删除项目版本会产生 "You cannot delete this version because it is used by a label"

google-apps-script - 将自变量/参数从 Google Sheets 自定义函数传递到脚本函数

google-apps-script - 使用 sendEmail() 接收重复的电子邮件

android - 从 Android 应用程序读取 Google 电子表格并列出该数据?

javascript - 如何通过Javascript访问HTML DOM中的Elements字段?

javascript - 单击不同的单选按钮后取消选中单选按钮

javascript - 文本框中的传输表 TD