こんにちは私はこのスプレッドシートの異なるタブに複数のタイムスタンプを含むようにスプレッドシートを作成しようとしています。列Jでデータが編集されるたびに、列Kにタイムスタンプがすぐに入力されるようにします。私は1枚のGoogleシート内に4枚のシートがあり、この自動タイムスタンプを個別に実行する必要があります。助けてくれてありがとう。私は他の投稿を見てみましたが、自分のために他の人のドキュメントからコードを変更するのは困難です。複数のタブにまたがる同じGoogleシートの複数のタイムスタンプ
このタイムスタンプを取得するために、次のスクリプト関数を使用していました。 Googleシートに1つのタブしかないときはうまくいきました。しかし、今では複数のタブがあり、1枚のシートしか更新されません。全体の文書全体で同じことをする方法を理解しようとしています。
function onEdit(event)
{
var timezone = "EST";
var timestamp_format = "MM-dd-yyyy HH:mm:ss"; // Timestamp Format.
var updateColName = "PM Status ";
var timeStampColName = "Date Update";
var sheet = event.source.getSheetByName('Walt'); //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);
}
}
プロパティ "source"を読み取ることができないということです –
私はvar ss = e.sourceを置き換えました。 with ss = SpreadsheetApp.getActiveSpreadsheet();しかし今は私にエラーを与えていますプロパティの範囲を読み取ることができません –
ここに編集権限を持つシートへのリンクがあります。ありがとう。 https://docs.google.com/spreadsheets/d/1DE_nd_viCCBYhTyeh92oNc5EOW2YfH5ZLuysfSCjjvM/edit?usp=sharing –