質問するログイン新規登録
Google スプレッドシート

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

Google Apps Script

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

Q&A

解決済

1回答

160閲覧

【GAS】hideColumns, showColumnsを使った列の非表示・再表示

chanyamon

総合スコア1

Google スプレッドシート

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

Google Apps Script

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

0グッド

0クリップ

投稿2025/03/05 05:46

0

0

実現したいこと

背景

画像のようなかたちで定例会議の内容をまとめているシートがあります。
イメージ説明
これまでは、「今週の会議が始まるときに前週の列を手動で非表示に設定」するという方法を繰り返してきました。
そのため、前週の内容だけ確認したいとき、1列ではなく膨大な量の非表示列が展開されてしまうという問題がありました。

やりたいこと

上記を解決すべく、
『一番左の列(画像でいうとC列)のみを非表示にするスクリプト』
『非表示の列のうち最後の1列のみを再表示するスクリプト』
を実装したいと考えています。

発生している問題・分からないこと

非表示スクリプトにおける問題

非表示にしたい列は必ず左から3列目になるため、列番号で指定してみました。
最初の1回は成功しましたが、非表示の列がすでに存在する場合は実行しても左から3列目が消えません。
おそらく列番号3という指定=C3セルのため表示されている列のみを数えることができていないのだと考えています。

再表示スクリプトにおける問題

行番号3、列番号3のセル番地を取得し、その一つ隣の列番号を再表示させるように書いてみました。
こちらも3,3でセルを指定するところが原因でうまくいかないのかと考えています。

該当のソースコード

GAS

1function hideColumn() { 2 // スプレッドシートを取得 3 var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); 4 5 // 非表示にしたい列番号を設定 6 var column = 3; 7 8 // 指定された列を非表示にする 9 sheet.hideColumns(column); 10}

GAS

1function unhideLeftNeighborColumnFromCell() { 2 // スプレッドシートを取得 3 var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); 4 5 // 指定したセル番地を取得 6 var cellRange = sheet.getRange(3, 3); // セル (3,3) を指定 7 var cellA1Notation = cellRange.getA1Notation(); 8 9 // 指定したセルの左隣の列番号を計算 10 var column = cellRange.getColumn(); 11 var leftNeighborColumn = column - 1; 12 13 // 左隣の列が存在する場合に非表示を解除 14 if (leftNeighborColumn > 0) { 15 sheet.showColumns(leftNeighborColumn); 16 } 17}

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

・列番号ではなくgetA1Notationでセル番地を取得するべき?
・offsetで絶対に表示されているセルからずらして取得するべき?
→非表示の列もカウントされてしまうため、表示を変更したい列の取得がスマートにできない。

初歩的な問題かもしれませんが、何卒よろしくお願いいたします。

補足

特になし

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

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

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

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

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

chanyamon

2025/03/05 07:36

ありがとうございます! 書いていただいたコードで無事に動きました。 応用して非表示を再表示させるバージョンも作成できました。 大変助かりました!
guest

回答1

0

ベストアンサー

非表示にされていても列は存在するのでB列より右に存在する現在表示されている列1列を非表示にする場合はループで表示状態か非表示状態かを判断し、表示状態であれば非表示とするといった処理になります。
表示状態か非表示状態かを判断するにはisColumnHiddenByUserを利用します。

javascript

1 var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); 2 3 for(i = 3; i<sheet.getLastColumn(); i++) { 4 if(sheet.isColumnHiddenByUser(i) == false){ 5 // 表示列を見つけたらその列を非表示にしループを抜ける 6 sheet.hideColumns(i); 7 break; 8 } 9 }

上記コードはイメージで書いたもので動作確認していません。

投稿2025/03/05 07:14

YAmaGNZ

総合スコア10679

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

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

chanyamon

2025/05/02 05:31

ありがとうございます! 書いていただいたコードで無事に動きました。 応用して非表示を再表示させるバージョンも作成できました。 大変助かりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問