📘 Excel逆引き事典

【VBA】特定の文字を含む行を抽出する方法

手作業で大量のデータから特定の文字列を含む行を探すのは大変な作業です。この記事では、VBAを使用して簡単にその作業を自動化し、効率的に業務を進めましょう。

サンプルコード

VBA
Option Explicit
Sub ExtractRowsWithoutPrompt()
    Dim ws As Worksheet, destWs As Worksheet
    Dim lastRow As Long, i As Long, destLastRow As Long
    
    Set ws = ThisWorkbook.Sheets("Sheet1") ' 対象のシート名を指定してください。
    Set destWs = ThisWorkbook.Sheets.Add ' 抽出結果を保存する新しいシートを作成します。
    lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row
    destLastRow = 1
    
    For i = 1 To lastRow
        If InStr(1, ws.Cells(i, 1).Value, "特定の文字", vbTextCompare) > 0 Then ' 条件を指定します。
            ws.Rows(i).Copy Destination:=destWs.Rows(destLastRow + 1)
            destLastRow = destLastRow + 1
        End If
    Next i
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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