📘 Excel逆引き事典

【VBA】開いている全ブックを高速に(画面更新停止)抽出する方法

日々の業務では、複数のExcelファイルを開いている状況がよくあります。これらのワークブックから必要な情報を一括で取り出す作業は手間がかかります。そこでこの記事では、開いている全てのワークブックを高速に抽出するVBAマクロを作成し、効率的な業務遂行をお手伝いします。

サンプルコード

VBA
Option Explicit
Sub ExtractAllOpenWorkbooks()
    Dim wb As Workbook, ws As Worksheet
    '画面更新停止
    Application.ScreenUpdating = False
    Set ws = ThisWorkbook.Sheets("抽出先")
    ws.Cells.ClearContents
    For Each wb In Application.Workbooks
        If Not wb.Name = ThisWorkbook.Name Then
            ws.Range("A1").Offset(ws.Rows.Count - 1).Value = wb.Name
        End If
    Next wb
    '画面更新再開
    Application.ScreenUpdating = True
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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