📘 Excel逆引き事典

【VBA】開いている全ブックを部分一致で削除する方法

日々の業務で大量のエクセルファイルを開いて作業をする場合、特定のパターンに一致するファイルを一括で閉じたいことはありませんか?この記事では、開いているすべてのワークブックから指定した文字列(部分一致)を持つファイル名のワークブックを削除するVBAマクロを作成します。これにより、効率的な作業環境を整えることができます。

サンプルコード

VBA
Option Explicit
Sub DeleteWorkbooksWithPartialMatch()
    Dim wb As Workbook, strSearch As String
    strSearch = "部分一致文字列"
    Application.ScreenUpdating = False
    For Each wb In Workbooks
        If InStr(1, wb.Name, strSearch) > 0 Then
            wb.Close SaveChanges:=False
        End If
    Next wb
    Application.ScreenUpdating = True
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

A.
部分一致文字列やワークブック名が正しいか確認してください。また、開いているワークブックに問題がないかも確認してください。