📘 Excel逆引き事典

【VBA】データの最終行をバックグラウンドで背景色を変える方法

日々の業務で大量のデータを扱う場合、特定の行を目立たせることが重要です。特に最終行は重要な情報を含むことが多いので、目視で簡単に見つけられるように背景色を変更したいですよね。この記事では、Excel VBAを使用して、指定したシートのデータの最終行に背景色を自動的に適用する方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub ChangeBackgroundColorOfLastRow()
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets("Sheet1") ' シート名を適切なものに変更してください。
    Application.ScreenUpdating = False ' バックグラウンド処理のため画面更新を停止

    Dim lastRow As Long
    lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row ' 最終行を取得

    For i = 1 To ws.Columns.Count ' 全ての列に対してループ
        If Not IsEmpty(ws.Cells(lastRow, i)) Then ' データがある場合
            With ws.Cells(lastRow, i)
                .Interior.ColorIndex = 6 ' 背景色を変更(ここでは青色に設定しています)
            End With
        End If
    Next i

    Application.ScreenUpdating = True ' 実行完了後、画面更新を再開
End Sub

よくある質問

Q 元に戻せますか?

A.
VBAの実行結果は「元に戻す」が効きません。必ずバックアップを取ってから実行してください。

Q エラーが出たら?

A.
シート名や列番号が正しいか確認してください。