📘 Excel逆引き事典

【VBA】開いている全ブックを開かずに別ブックとして保存する方法

手作業での大量のエクセルファイル操作は効率が悪く、ミスも増えます。この記事では、開いていない他のワークブックからデータをコピーし、新しいファイルとして保存するVBAマクロを作成します。これにより、業務効率を大幅に向上させることができます。

サンプルコード

VBA
Option Explicit
Sub SaveWorkbookAsNewFile()
    Dim wb As Workbook, ws As Worksheet
    Dim sourcePath As String, targetPath As String
    
    ' 外部参照先のワークブックパスとシート名を指定
    sourcePath = "C:\path\to\source.xlsx"
    Set ws = Workbooks.Open(sourcePath).Sheets("Sheet1")
    
    ' 新規ファイル保存用のパスを指定
    targetPath = "C:\path\to\target.xlsx"
    
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    
    ws.Copy
    Set wb = ActiveWorkbook
    wb.SaveAs Filename:=targetPath, FileFormat:=xlOpenXMLWorkbook
    wb.Close SaveChanges:=True
    
    Workbooks(sourcePath).Close SaveChanges:=False
    
    Application.ScreenUpdating = True
    Application.DisplayAlerts = True
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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