実現したいこと
発生している問題・分からないこと
前の処理が完了する前に次の処理に進んでしまうため、途中でSpreadsheetApp.flush()を使っていますが処理が遅くなってしまいます。
速くする方法はありますでしょうか?
該当のソースコード
function arrangeMacro2() { var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); // 適用する範囲のセルを取得 var range = sheet.getActiveRange();//適用する範囲を取得 var values = range.getValues();//範囲内のセルを配列に格納 var cellFormula = range.getFormulas();//セルの数式を取得 var formula = "=INDIRECT(ADDRESS(ROW()-1,COLUMN()))";//数式を定義 range.setBorder(true, true, true, true, true, true);//罫線を引く //指定された範囲内のセルに対して処理を行う for (var i = 0; i < values.length; i++) { for (var j = 0; j < values[i].length; j++) { // セルが空白だった場合、上線を削除し、上セルのコピーを入力する if (values[i][j] == "" || cellFormula[i][j] == formula) { var cell = range.getCell(i + 1, j + 1);//セルを取得 cell.setBorder(false, true, true, true, true, true).setFormula(formula).setFontColor('#CCCCCC'); SpreadsheetApp.flush(); } // 左端の列以外で、左のセルが数式ではない時、上線と「-」を入力する if (j > 0 && ((values[i][j] == "-") || (values[i][j - 1] == "-") || (cellFormula[i][j] == formula && cellFormula[i][j - 1] != formula))) { var cell = range.getCell(i + 1, j + 1);//セルを取得 cell.setBorder(true, true, true, true, true, true).setValue("-").setFontColor('#000000'); } } } }
試したこと・調べたこと
- teratailやGoogle等で検索した
- ソースコードを自分なりに変更した
- 知人に聞いた
- その他
上記の詳細・結果
特定のセルを配列に格納していき最後にまとめてgetRangeを使って処理しようとしましたが、対象となるセルがバラバラの位置にあるため上手くできませんでした。
補足
特になし
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2025/01/17 15:15