実現したいこと
すべてのシートに同じ範囲の保護を一括で行う方法が知りたいです。
下記のようなプログラムではなく、別のプログラムのほうが、よいでしょうか?
前提
すべてのシートの「A1:F34」の範囲で、シートのオーナーである【自分のみ】の権限において保護を、一括で行いたいと考えています。
発生している問題・エラーメッセージ
「該当のソースコード」に記載しているプログラムを使用としましたが、エラーがでました。
Exception: Invalid argument: id sheetCopyProtect @ 無題.gs:9
該当のソースコード
"use strict"; // 変数の宣言を強要 function sheetCopyProtect( ) { const spread = SpreadsheetApp.getActive( ); // 現在のスプレッドシートを取得 const sheet = SpreadsheetApp.getActiveSheet( ); // 現在のシートを取得 let sheetValues = sheet.getDataRange( ).getValues( ); // シートに入力されている内容をすべて取得 // 処理の対象となるスプレッドシートを開く const target = SpreadsheetApp.openById( sheetValues[ 0 ][ 1 ] ); const targetSheet = target.getActiveSheet( ); spread.toast( "スプレッドシート『" + target.getName( ) + "』の" + "シート「" + targetSheet.getName( ) + "」を、" + "指定されたユーザーごとに複製して保護します。" ); // 4列目以降に、処理の対象となるデータが保存されているはず for ( let i = 4 - 1 ; i < sheetValues.length ; i++ ) { if ( sheetValues[ i ][ 0 ] != "" ) { // シートに対象となるデータが入力されていれば、処理する // まずは、シートを複製する let copySheet = targetSheet.copyTo( target ); // シート名を変更する copySheet.setName( sheetValues[ i ][ 0 ] ); // シートを保護する let protctInfo = copySheet.protect( ); protctInfo.addEditor( sheetValues[ i ][ 1 ] ); // 編集者を追加 } else { break; // 入力されている内容がなくなったので、くり返し終了 } } spread.toast( "複製と保護が終了しました。" );
試したこと
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
「該当のソースコード」を試しましたが、ダメでした。
すべてのシートの「A1:F34」の範囲で、シートのオーナーである【自分のみ】の権限において保護を、一括で行いたいと考えています。
という処理とお示しいただいたスクリプトの処理(指定ファイルの指定シート全体の複製と保護)は異なるようです。
それはさておき、ご質問のすべてのシートというのは、
スクリプトが保存されているスプレッドシートの全てのシートで同じセル範囲を保護することで
よろしいのでしょうか。
それとも、
スクリプトが保存されているスプレッドシートとは異なるスプレッドシートを指定して
その中の全てのシートの同じセル範囲を保護設定したいのでしょうか。

回答1件
あなたの回答
tips
プレビュー