回答編集履歴
3
コード内のコメント追加
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
全部変更
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
|
-

|
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行目と
|
11
|
+
// 項目1基準で、全範囲を取得(1行目と最終行を除く)
|
24
|
-
const allRange = sheet.getRange(2,
|
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
|
-
//
|
16
|
+
// F列(パーセント)の値を取得
|
29
|
-
const value = sheet.getRange(
|
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
|
-
//
|
23
|
+
// 35%以上という条件を満たす値のうち、最後尾にある値が、配列の何番目にあるかインデックスを取得
|
32
|
-
|
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
|
-
//
|
28
|
+
// インデックス番号+1する(=スプレッドシートの行番号)
|
36
|
-
const
|
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
誤字修正
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
|
|