簡體   English   中英

Google Apps Scripts - 更新時向多個單元格添加時間戳

[英]Google Apps Scripts - Add Timestamp to multiple cells when updated

我正在嘗試更新本教程中的代碼以在更新單元格時添加時間戳。 到目前為止,它在將值復制到整個范圍時適用於第一個單元格,但不是所有單元格。

有人可以看看並幫助調整這一點,以便所有單元格都使用時間戳更新,而不僅僅是第一個?

謝謝!

 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(日期);

使用getRange(row, column, numRows)檢索具有多行的范圍。 如果我們改變它:

sheet.getRange(索引,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);
  }
}

參考:

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM