📘 Excel逆引き事典

【VBA】空白セルを開かずに(外部参照で)コピーする方法

日々の業務では、他のワークブックからデータをコピーすることがよくあります。しかし、大量の空白セルがある場合、それらを開くのは効率が悪くなります。この記事では、VBAを使って外部参照で空白セルをコピーする方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub CopyBlankCells()
    Dim wbSource As Workbook, wsSource As Worksheet
    Dim wbTarget As Workbook, wsTarget As Worksheet
    Dim lastRow As Long, i As Long
    
    ' ソースワークブックとターゲットワークブックを指定
    Set wbSource = Workbooks("source.xlsx")
    Set wbTarget = ThisWorkbook
    Set wsSource = wbSource.Sheets("Sheet1")
    Set wsTarget = wbTarget.Sheets("Sheet2")
    
    ' 画面更新を停止して処理速度を向上させる
    Application.ScreenUpdating = False
    
    ' ソースワークシートの最終行を取得
    lastRow = wsSource.Cells(wsSource.Rows.Count, "A").End(xlUp).Row
    
    ' ループで各セルをコピー
    For i = 1 To lastRow
        If IsEmpty(wsSource.Range("A" & i)) Then
            wsTarget.Range("B" & i) = "=" & wbSource.Name & "!" & wsSource.Range("A" & i).Address
        End If
    Next i
    
    ' 画面更新を再開
    Application.ScreenUpdating = True
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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