📘 Excel逆引き事典

【VBA】数式エラー(#N/A等)を含むデータを別ブックとして保存する方法

日々の業務では、エクセル内で#N/Aなどの数式エラーが発生することがあります。しかし、これらのエラーを含むデータを別のファイルに移動させたい場合、通常は確認メッセージが出力され、作業が中断されます。この記事では、そのような状況でもスムーズに別ブックとして保存する方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub SaveSheetWithErrorAsNewBook()
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets("シート1")
    
    ' 新しいワークブックを作成
    Dim newWb As Workbook
    Set newWb = Workbooks.Add
    
    ' エラーチェックを無視してデータコピー
    Application.DisplayAlerts = False
    ws.Cells.Copy Destination:=newWb.Sheets(1).Cells
    Application.DisplayAlerts = True
    
    ' 新しいワークブックを保存
    newWb.SaveAs ThisWorkbook.Path & "\エラーデータ.xlsx"
    newWb.Close SaveChanges:=True
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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