【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.
シート名や列番号が正しいか確認してください。