GASでスプレッドシートで閉じた行グループを開くには「expandGroups()
」を利用する。
expandGroups()
範囲またはコントロールトグルがこの範囲と交差する折りたたまれたグループを展開します。コントロールトグルの場所は、設定に応じてグループの直前または直後に、コントロールトグルが表示されるインデックスです。同じ場所に複数のグループがある場合は、最も浅いグループが展開されます。
https://developers.google.com/apps-script/reference/spreadsheet/range#expandgroups
関連記事:【GAS】スプレッドシートのグループ化された行を閉じる
expandGroups()の戻り値
Range—この範囲、連鎖用。
スプレッドシートで閉じた行グループを開くGAS
function myFunction() {
//アクティブなスプレッドシートを返す
var ss = SpreadsheetApp.getActiveSpreadsheet();
//アクティブな0番目のシートを返す
var sht = ss.getSheets()[0];
//テキストを変数へ格納
var array1,array2,array3
array1 = "Spread";
array2 = "Sheet";
array3 = ".BLUE";
//変数を繰り返しA~D列の10行目まで入力
for(let i=1;i<11; i++){
sht.getRange(i,1).setValue(array1);//10行目までarray1をセット
sht.getRange(i,2).setValue(array2);//10行目までarray2をセット
sht.getRange(i,3).setValue(array3);//10行目までarray3をセット
sht.getRange(i,4).setValue(i);//10行目まで連番をセット
}
//shiftRowGroupDepthで3行目をグループ化にする
var rng = sht.getRange(3,1,3,1); //3行目1列目から3行分アクティブ1列の範囲
rng.shiftRowGroupDepth(1); //1行分だけグループ化
rng.collapseGroups(); //グループ化の範囲を閉じる
//メッセージボックスでYESNOを確認
var result = Browser.msgBox("グループ化で閉じてる行を表示しちゃう?",Browser.Buttons.YES_NO);
if(result=="no"){
Browser.msgBox("グループ化を閉じたままにするね!");//noだったら閉じたまま
}else{
rng.expandGroups();//yesなら開く
Browser.msgBox("グループ化閉じを表示しちゃった!");//開いたメッセージを掲載!
}
}
スプレッドシートで閉じた行グループを開くGAS実行の様子
expandGroups()メソッドを利用して、スプレッドシートで閉じた行グループを開くGASを実行してみました。
スプレッドシートのグループ化された行を閉じない場合
expandGroupsを実行しないとき、グループ化された行は閉じたままになっています。
スプレッドシートで閉じた行グループを開く場合
expandGroupsを実行すると、グループ化された行が展開されています。
スプレッドシートで閉じた行グループを開くまとめ
GAS×スプレッドシートで閉じた行グループを開くならexpandGroups()
メソッドを利用しましょう。
関連記事:【GAS】スプレッドシート指定の行グループを表示・指定外の行を非表示にする
関連記事:【GAS】スプレッドシートの指定行をグループ化する
関連記事:【GAS】スプレッドシートの指定行から複数行を非表示にする
関連記事:【GAS】スプレッドシートで行の非表示を再表示する
関連記事:【GAS】スプレッドシートの指定行の後ろに複数行を追加する
関連記事:【GAS】スプレッドシートの指定行の前に複数行を追加する
参考記事:【GAS】スプレッドシートに行を挿入する