📘 Excel逆引き事典

【VBA】特定の文字を含む行を確認メッセージを出さずに値をクリアする方法

日々の業務では、特定の文字列を含むセルの内容を削除することがあります。この作業は手動で行うと時間がかかります。そこで、本記事ではVBAを使用して、特定の文字列を含む行のデータを自動的にクリアする方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub ClearCellsContainingSpecificText()
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets("Sheet1") ' シート名を指定してください
    
    Application.ScreenUpdating = False ' 画面更新を停止
    Application.DisplayAlerts = False ' 確認メッセージの表示をオフに
    
    Dim lastRow As Long
    lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row ' 最終行取得
    
    Dim i As Long
    For i = lastRow To 1 Step -1 ' 行を逆順に処理
        If InStr(ws.Cells(i, 1), "特定の文字") > 0 Then ' 特定の文字が含まれる場合
            ws.Rows(i).ClearContents ' 値をクリア
        End If
    Next i
    
    Application.ScreenUpdating = True ' 画面更新を再開
    Application.DisplayAlerts = True ' 確認メッセージの表示をオンに
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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