2017-09-08 14 views
1

こんにちは私はこのスプレッドシートの異なるタブに複数のタイムスタンプを含むようにスプレッドシートを作成しようとしています。列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); 
    } 
} 

答えて

0

ここに移動します。 onEdit()トリガを設定します。私はそれをテストしました。できます。現在のところ、スプレッドシート内のすべてのシートで機能しますが、特定のシートに制限するのは簡単です。 var wantedSheets=['Sheet1','Sheet2','Sheet3','Sheet4'];のような配列に必要なシートをすべて入れて、wantedSheets.indexOf()を実行して、現在のシートが入っているかどうかを調べることができます。

function onTimeStampEdit(e) 
{ 
    var ss=e.source; 
    var sh=ss.getActiveSheet(); 
    var rg=e.range; 
    var row=rg.getRow(); 
    var col=rg.getColumn(); 
    if(col==9 || col==10) 
    { 
     sh.getRange(row,11).setValue(Utilities.formatDate(new Date(), Session.getScriptTimeZone(), "MM/dd/yyyy HH:mm:ss")); 
    } 
} 

これを使用して、インストール可能なトリガーを設定できます。 SpreadsheetIdを追加するだけです。

function installOnEditTrigger() 
{ 
    setupTrigger('onTimeStampEdit','SpreadsheetId'); 
} 

function setupTrigger(funcName,SpreadsheetId) 
{ 
    if(!isTrigger(funcName)) 
    { 
    ScriptApp.newTrigger(funcName).forSpreadsheet(SpreadsheetId).onEdit().create(); 
    } 
} 

function isTrigger(funcName) 
{ 
    var r=false; 
    if(funcName) 
    { 
    var allTriggers=ScriptApp.getProjectTriggers(); 
    var allHandlers=[]; 
    for(var i=0;i<allTriggers.length;i++) 
    { 
     allHandlers.push(allTriggers[i].getHandlerFunction()); 
    } 
    if(allHandlers.indexOf(funcName)>-1) 
    { 
     r=true; 
    } 
    } 
    return r; 
} 
+0

プロパティ "source"を読み取ることができないということです –

+0

私はvar ss = e.sourceを置き換えました。 with ss = SpreadsheetApp.getActiveSpreadsheet();しかし今は私にエラーを与えていますプロパティの範囲を読み取ることができません –

+0

ここに編集権限を持つシートへのリンクがあります。ありがとう。 https://docs.google.com/spreadsheets/d/1DE_nd_viCCBYhTyeh92oNc5EOW2YfH5ZLuysfSCjjvM/edit?usp=sharing –

関連する問題