回答編集履歴

3

コード内のコメント追加

2022/12/27 15:14

投稿

Cocode
Cocode

スコア2316

test CHANGED
@@ -27,6 +27,7 @@
27
27
  if (targetPercentIndex >= 0) {
28
28
  // インデックス番号+1する(=スプレッドシートの行番号)
29
29
  const targetPercentRow = targetPercentIndex + 1;
30
+ // 35%以上の最後尾の行に、赤線を引く
30
31
  sheet.getRange(targetPercentRow, 1, 1, lastCol).setBorder(null, null, true, null, null, null, '#FF0000', SpreadsheetApp.BorderStyle.SOLID_MEDIUM)
31
32
  } // 35%以上の値が存在しない場合は何もしない
32
33
  }

2

全部変更

2022/12/27 15:09

投稿

Cocode
Cocode

スコア2316

test CHANGED
@@ -1,40 +1,33 @@
1
- なさりたいことの解釈を間違っていたら申し訳ございません。
2
- 以下前提条件でコードを組んでみました。
1
+ 質問が更新されましたので、内容・コード刷新しました。
3
- 参考になれば幸す。
2
+ 以下でご希望の動作が実装できると思す。
4
3
 
5
- ### 前提条件
6
- - A列には線を引かない。
7
- - F列にパーセントの数字が入力されている。
8
- - 全行の下側に灰色の点線を引く(ただし、A列と1行目(ヘッダー)は除く)。
9
- - 最終行には以下のいずれかの下線を引く。
10
- - 最終行のF列のパーセントが35%以上だった場合 → 赤色・中太線
11
- - 35%未満だった場合 → 黒色・細線
12
-
13
- ### コード例
14
- ※見にくかったため、灰色の代わりに青色の点線を引いています。
15
- ![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2022-12-27/ec23a78f-b867-4150-9e92-63b4a466b453.png)
4
+ ![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2022-12-28/4eadd106-25c9-424d-bf95-5d32057dab87.png)
16
-
17
5
  ```javascript
18
6
  function setBorders() {
19
7
  const sheet = SpreadsheetApp.getActiveSheet();
20
8
  const lastRow = sheet.getLastRow();
21
9
  const lastCol = sheet.getLastColumn();
22
-
10
+
23
- // 全範囲取得(1行目とA列は含まない
11
+ // 項目1基準で、全範囲取得(1行目と最終行を除く
24
- const allRange = sheet.getRange(2, 2, lastRow - 1, lastCol - 1);
12
+ const allRange = sheet.getRange(2, 1, lastRow - 2, lastCol);
25
- // 全範囲青色の点線を引く
13
+ // 全範囲青色の点線を引く
26
14
  allRange.setBorder(null, null, true, null, null, true, "#0000FF", SpreadsheetApp.BorderStyle.DOTTED);
27
15
 
28
- // 最終行のF列の値を取得(パーセントの数字)
16
+ // F列(パーセント値を取得
29
- const value = sheet.getRange(lastRow, 6).getValue();
17
+ const values = sheet.getRange('F:F').getValues().flatMap(([val]) => val ? val : []);
18
+ // F列の長さ(=F列の最終行)を取得
19
+ const lastPercentRow = values.length;
20
+ // F列の最終行に黒線を引く
21
+ sheet.getRange(lastPercentRow, 1, 1, lastCol).setBorder(null, null, true, null, null, null, '#000000', SpreadsheetApp.BorderStyle.SOLID);
30
22
 
31
- // 値が35%以上なら定数color赤色定数style中太線代入する。
23
+ // 35%以上という条件を満たす値のうち最後尾ある値が配列の何番目あるかインデックス取得
32
- // 値が35%未満なら、定数colorに黒色、定数styleに細線を代入する。
24
+ const targetPercentIndex = values.findLastIndex(val => val >= 0.35);
33
- const [color, style] = value >= 0.35 ? ['#FF0000', SpreadsheetApp.BorderStyle.SOLID_MEDIUM] : ['#000000', SpreadsheetApp.BorderStyle.SOLID];
34
25
 
26
+ // インデックス番号が0以上の場合(つまり、配列の中に値が存在する場合)
27
+ if (targetPercentIndex >= 0) {
35
- // 最終の線を引きたい範囲のみを取得(A列は含まない
28
+ // インデックス番号+1する(=スプレッドシートの番号
36
- const lastRange = sheet.getRange(lastRow, 2, 1, lastCol - 1);
29
+ const targetPercentRow = targetPercentIndex + 1;
30
+ sheet.getRange(targetPercentRow, 1, 1, lastCol).setBorder(null, null, true, null, null, null, '#FF0000', SpreadsheetApp.BorderStyle.SOLID_MEDIUM)
37
- // 最終行に線を引く
31
+ } // 35%以上の値が存在しない場合は何もしない
38
- lastRange.setBorder(null, null, true, null, null, null, color, style);
39
32
  }
40
33
  ```

1

誤字修正

2022/12/26 18:54

投稿

Cocode
Cocode

スコア2316

test CHANGED
@@ -5,7 +5,7 @@
5
5
  ### 前提条件
6
6
  - A列には線を引かない。
7
7
  - F列にパーセントの数字が入力されている。
8
- - 全行の下側に灰色の点線を引く(ただし、A列と最終行は除く)。
8
+ - 全行の下側に灰色の点線を引く(ただし、A列と1目(ヘッダー)は除く)。
9
9
  - 最終行には以下のいずれかの下線を引く。
10
10
  - 最終行のF列のパーセントが35%以上だった場合 → 赤色・中太線
11
11
  - 35%未満だった場合 → 黒色・細線
@@ -28,7 +28,7 @@
28
28
  // 最終行のF列の値を取得(パーセントの数字)
29
29
  const value = sheet.getRange(lastRow, 6).getValue();
30
30
 
31
- // 値が35%以上なら、定数colorに赤色、定数styleに中太線を代入。
31
+ // 値が35%以上なら、定数colorに赤色、定数styleに中太線を代入する
32
32
  // 値が35%未満なら、定数colorに黒色、定数styleに細線を代入する。
33
33
  const [color, style] = value >= 0.35 ? ['#FF0000', SpreadsheetApp.BorderStyle.SOLID_MEDIUM] : ['#000000', SpreadsheetApp.BorderStyle.SOLID];
34
34