VBAサンプル集
他ブックを開いて閉じる(Open,Close)

ExcelマクロVBAの実用サンプル、エクセルVBA集と解説
最終更新日:2020-04-15

他ブックを開いて閉じる(Open,Close)


他のExcelブックを開いて、何らかの処理(転記等)を実行した後に、そのブックを閉じる。
VBAでは、よくあるパターンですね。
ワークシート関数では出来ない、VBAならではの処理とも言えます。


以下では、他ブックを開いて閉じる場合の基本的なVBAサンプルと簡単な解説をします。
それぞれのVBAでの違いは、開いたブックをその後にどのように指定するかと言うところになります。

パターン1:ActiveWorkbook

Sub sample1()
  Dim strBookName As String
  Workbooks.Open "ブックのフルパス"
  strBookName = ActiveWorkbook.Name
  ・・・処理
  Workbooks(strBookName).Close SaveChanges:=False
End Sub

"ブックのフルパス"は、"C:\ExcelFolder\Book1.xlsx"等です。
Openしたブックはアクティブ(一番前面に出ている)になっています。
つまりそれがActiveWorkbookです。
ActiveWorkbook.Nameを変数に入れて、それ以降のブック指定に使用しています。
保存が必要な時は、SaveChanges:=Trueとして下さい。

初級の初級といえる使い方ではありますが、だからこそ基本とも言えます。
次の段階に進むと、このようなVBAを書くことは無くなりますが、基本として必ず覚えておくべきものです。

サイト内の参考ページ

第63回.ブックを開く(Open)
・Workbooks.Openメソッド ・Openメソッドの使用例 ・Openメソッドの戻り値の使い方 ・Workbooks.Addメソッド ・Openメソッドの関連記事
第64回.ブックを閉じる・保存(Close,Save,SaveAs)
・ブックを閉じる ・ブックを上書き保存 ・ブックに名前を付けて保存 ・ブックのコピーを保存 ・ブックを閉じる・保存の実践例

パターン2:Workbooks.Count

Sub sample2()
  Workbooks.Open "ブックのフルパス"
  '・・・処理
  Workbooks(Workbooks.Count).Close SaveChanges:=False
End Sub

OpenしたブックはWorkbooksコレクションに追加されます。
つまり、Workbooksの最後が開いたブックになります。
Workbooks.Countは、開いているブック数です。
つまり、Workbooks(Workbooks.Count)は最後に開いたブックになります。

考え方としては覚えておくべきことですが、このVBAを実際に使う事は無いと思います。

サイト内の参考ページ

第53回.Workbookオブジェクト
・WorkBookの指定方法 ・WorkBookのデータ型 ・WorkBookのプロパティとメソッド ・Workbookオブジェクトの使用例 ・プロパティとメソッドの違い

パターン3:オブジェクト変数

Sub sample3()
  Dim wb As Workbook
  Set wb = Workbooks.Open("ブックのフルパス")
  ・・・処理
  wb.Close SaveChanges:=False
End Sub

Openメソッドの戻り値(開いたブックのオブジェクト)を変数に入れています。
オブジェクト変数への代入はSetステートメントを使用します。
これ以降は、このオブジェクト変数を使う事で開いたブックに対して処理することができます。

この使い方は、初心者から上級者まで使う最も基本的なVBAになります。

サイト内の参考ページ

第51回.Withステートメント
・Withの構文 ・Withを使った時と使わない時の比較 ・Withの使用例 ・Withのネスト ・Withを使ったときに気を付けるべき書き方 ・Withの使いどころ ・サイト内の参考ページ
第52回.オブジェクト変数とSetステートメント
・オブジェクト変数 ・個有のオブジェクト型とは ・Setステートメント ・Setステートメントの使用例 ・WithとSetの使い分け方 ・Setステートメントの実践的な使い方 ・Is演算子によるオブジェクトの比較 ・最後に

パターン4:Withステートメント

Sub sample4()
  With Workbooks.Open("ブックのフルパス")
    '・・・処理
    .Close SaveChanges:=False
  End With
End Sub

Openメソッドの戻り値(開いたブックのオブジェクト)をWithに指定しています。
Withの中(End Withまで)では、.ドットから書き始めることでWithに指定したオブジェクトの記述を省略できます。

変数が必要なくなりVBA記述が短くて済みますが、
使用するのは、End Withの手前で必ずブックを閉じる場合のみに限定されます。
Withの中でCloseしない場合は、結局パターン1等でブックを特定することになり、返って悪いVBAとなってしまいます。

サイト内の参考ページ

第51回.Withステートメント
・Withの構文 ・Withを使った時と使わない時の比較 ・Withの使用例 ・Withのネスト ・Withを使ったときに気を付けるべき書き方 ・Withの使いどころ ・サイト内の参考ページ
第52回.オブジェクト変数とSetステートメント
・オブジェクト変数 ・個有のオブジェクト型とは ・Setステートメント ・Setステートメントの使用例 ・WithとSetの使い分け方 ・Setステートメントの実践的な使い方 ・Is演算子によるオブジェクトの比較 ・最後に

パターン5:オブジェクト変数+Withステートメント

Sub sample5()
  Dim wb As Workbook
  Set wb = Workbooks.Open("C:\Users\yamao\Desktop\Book1.xlsx")
  With wb
    '・・・処理
    .Close SaveChanges:=False
  End With
End Sub

パターン3とパターン4を組み合わせて使用しています。
全体構想の考えがまとまっておらず、とりあえず書き始めるなら、このようにしておくと融通が効きやすい場合が多いでしょう。
もちろん、ワークシートのオブジェクト変数を使ったりする過程で、VBAの書きやすさ見やすさとの兼ね合いになります。

開いているブックをブック名で検索し閉じる場合

ついでに、開いているブックをブック名で検索し閉じる場合のVBAも紹介しておきます。

Sub sample6()
  Dim i As Long
  For i = 1 To Workbooks.Count
    If Workbooks(i).Name Like "*○○○*" Then
      Workbooks(i).Close SaveChanges:=False
    End If
  Next i
End Sub

Sub sample7()
  Dim wb As Workbook
  For Each wb In Workbooks
    If InStr(wb.Name, "○○○") > 0 Then
      wb.Close SaveChanges:=False
    End If
  Next
End Sub

上記2つのVBAは同じことをしています。
Workbooksコレクションを処理する場合として、For...Nextで処理するか、For Each...Nextで処理するかの違いと、
Likeでワイルドカードを使う場合と、InStrで文字列位置を取得するかの違いです。

これは、好みによって使い分ければ良いのですが、どちらのVBAも書けるようになっていた方が良いでしょう。



同じテーマ「マクロVBAサンプル集」の記事

重複削除してコピー(AdvancedFilter)
ブックを安全確実に開く方法(Open)
ブックを閉じる(Close)
他ブックを開いて閉じる(Open,Close)
ブックを開かずにセル値を取得(ExecuteExcel4Macro,Excel.Application)
罫線を簡単に引く(Borders,BorderAround)
マクロVBAの開始時と終了時に指定しておくべきApplicationのプロパティ
オートフィルター(AutoFilter)
日付のオートフィルタ(AutoFilter)
印刷ダイアログを使用する(xlDialogPrint)
名前定義の一覧と削除(Name)


新着記事NEW ・・・新着記事一覧を見る

数字(1~50)を丸付き数字に変換するVBA|VBA技術解説(2022-11-15)
TEXTAFTER関数(テキストの指定文字列より後ろの部分を返す)|エクセル入門(2022-11-14)
TEXTBEFORE関数(テキストの指定文字列より前の部分を返す)|エクセル入門(2022-11-14)
TEXTSPLIT関数(列と行の区切り記号で文字列を分割)|エクセル入門(2022-11-12)
LAMBDA以降の新関数はVBAで使えるか|VBA技術解説(2022-11-11)
WRAPCOLS関数(1次元配列を指定数の列で折り返す)|エクセル入門(2022-11-08)
WRAPROWS関数(1次元配列を指定数の行で折り返す)|エクセル入門(2022-11-08)
EXPAND関数(配列を指定された行と列に拡張する)|エクセル入門(2022-11-07)
TAKE関数(配列の先頭/末尾から指定行/列数を取得)|エクセル入門(2022-11-06)
DROP関数(配列の先頭/末尾から指定行/列数を除外)|エクセル入門(2022-11-06)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Excelショートカットキー一覧|Excelリファレンス
7.並べ替え(Sort)|VBA入門
8.エクセルVBAでのシート指定方法|VBA技術解説
9.マクロって何?VBAって何?|VBA入門
10.ExcelマクロVBAの基礎を学習する方法|エクセルの神髄




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ