質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Q&A

解決済

1回答

2432閲覧

すべてのシートに同じ範囲の保護を一括で行う方法って、ありますか?

touch.touch

総合スコア1

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

0グッド

2クリップ

投稿2023/12/06 14:13

編集2023/12/06 14:17

実現したいこと

すべてのシートに同じ範囲の保護を一括で行う方法が知りたいです。

下記のようなプログラムではなく、別のプログラムのほうが、よいでしょうか?

前提

すべてのシートの「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/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

touch.touch

2023/12/06 14:45

「該当のソースコード」を試しましたが、ダメでした。
YellowGreen

2023/12/07 00:49 編集

すべてのシートの「A1:F34」の範囲で、シートのオーナーである【自分のみ】の権限において保護を、一括で行いたいと考えています。 という処理とお示しいただいたスクリプトの処理(指定ファイルの指定シート全体の複製と保護)は異なるようです。 それはさておき、ご質問のすべてのシートというのは、 スクリプトが保存されているスプレッドシートの全てのシートで同じセル範囲を保護することで よろしいのでしょうか。 それとも、 スクリプトが保存されているスプレッドシートとは異なるスプレッドシートを指定して その中の全てのシートの同じセル範囲を保護設定したいのでしょうか。
guest

回答1

0

ベストアンサー

コメントで質問しましたが、
どちらでもあまり変わりはないので、スクリプトの例をお示しします。

JavaScript

1//保護の設定 2function protectAllSheet() { 3 //保護対象セル範囲の指定 4 const cells = 'A1:F34'; 5 //保護の説明 6 const despriction = 'オーナーのみが編集可能'; 7 //スプレッドシートを取得 8 const ss = SpreadsheetApp.getActiveSpreadsheet(); 9 // const ss = SpreadsheetApp.openById('xxxxxxxxxxxxxx'); //他のファイルならこちら 10 //全てのシートを配列に取得 11 const sheets = ss.getSheets(); 12 //スクリプトを実行しているユーザーを取得 13 const me = Session.getEffectiveUser(); 14 //シートごとに繰返し 15 for (const sheet of sheets) { 16 //保護設定対象のセル範囲 17 const range = sheet.getRange(cells); 18 //セル範囲の保護を作成(この段階ではセル範囲に保護設定されるが誰でも編集可能) 19 const protection = range.protect().setDescription(despriction); 20 //権限所有者を自分に設定 21 protection.addEditor(me); 22 } 23} 24 25//保護の削除 26function removeProtections() { 27 //保護対象セル範囲の指定 28 const cells = 'A1:F34'; 29 //スプレッドシートを取得 30 const ss = SpreadsheetApp.getActiveSpreadsheet(); 31 // const ss = SpreadsheetApp.openById('xxxxxxxxxxxxxx'); //他のファイルならこちら 32 //全てのシートを配列に取得 33 const sheets = ss.getSheets(); 34 //シートごとに繰返し処理 35 for (const sheet of sheets) { 36 //セル範囲の保護を全て配列に取得 37 const protections = sheet.getProtections(SpreadsheetApp.ProtectionType.RANGE); 38 //取得した範囲ごとに繰返し 39 for (const protection of protections) { 40 //保護対象のセル範囲が一致したら、保護を削除 41 if (protection.getRange().getA1Notation() == cells) { 42 if (protection.canEdit()) { 43 protection.remove(); 44 } 45 } 46 } 47 } 48}

投稿2023/12/07 01:00

YellowGreen

総合スコア861

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

touch.touch

2023/12/07 01:20

私が求めていたプログラムでした。 いつも迅速かつ丁寧に応対してくださり、心から感謝しています。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問