VBA入門
第53回.Workbookオブジェクト

ExcelマクロVBAの基本と応用、エクセルVBAの初級・初心者向け解説
最終更新日:2021-04-28

第53回.Workbookオブジェクト


Workbookオブジェクトは、ワークブックそのものです。
1つのワークブックは、1つのExcelファイルです。
マクロVBAで複数のブックを扱う場合や、ブックを読込んだり保存したりする場合は、
Workbookオブジェクトをしっかり意識しつつVBAを記述しなければなりません。


WorkBookの指定方法

Workbooks("ブック名")
ブック名で指定されるブックです。
Workbooks(インデックス)
ブックを開いた順番の数値で指定しますが、
これは使う事はほぼないでしょう。
ActiveWorkbook
アクティブなブック、これは常に一つだけです。
ThisWorkbook
動作しているマクロが書いてあるブックです。
これらで参照されるオブジェクトがWorkbookオブジェクトになります。
ここで記述しているWorkbooks等は、Applicationのプロパティになります。

VBA マクロ Workbook

Applicationのプロパティについては、少し後の回に詳しく説明します。

WorkBookのデータ型

データ型は、
Workbook
つまり、



Dim 変数 As Workbook

このように使います。
気を付けてもらいたいのは、
Workbooks
ではないと言う事です。
データ型のWorkbookは複数形ではないので、最後のsは付きません。

Workbooksは、Workbookの集まりで、コレクションと言います。
コレクションについては、後々説明いたします。
Workbooksコレクションの中から、特定のブックを指定したものが、Workbookオブジェクトになります。

WorkBookのプロパティとメソッド

WorkBookオブジェクトに含まれるプロパティ・メソッドは、非常にたくさんあります。
WorkBookのプロパティ、メソッド、イベントの一覧
エクセルの基本である、WorkBookオブジェクトのプロパティ、メソッド、イベントの一覧です。覚えるというより、必要に応じて調べて使うものになります。WorkBookオブジェクトのプロパティ一覧 WorkBookオブジェクトのメソッド一覧 名前 説明 AcceptAllChanges 指定された共有ブックのすべての変更を反映します。
ごく一部、良く使うものを以下に紹介します。

プロパティ Name 名前
Names 名前定義
Path 保存パス
FullName 保存パス+名前
Saved 最後の保存から変更されたかを取得・設定
ReadOnly 読み取り専用かを取得・設定
Sheets 全てのシート
Worksheets 全てのワークシート
メソッド ActiVate アクティブにします
Close 閉じる
Save 上書き保存
SaveAs 名前を付けて保存
SaveCopyAs コピーを保存
PrintOut 印刷
PrintPreview 印刷プレビュー
Protect 保護
Unprotect 保護を解除

今までに出てきたのは、Activateくらいです。
個々の使い方については、今後少しづつ紹介します。

Workbookオブジェクトの使用例



Dim wb As Workbook
Set wb = Workbooks("Book1.xlsx")
MsgBox wb.Name

メッセージボックスには、「Book1.xlsx」と表示されます。
Workbookの集まりWorkbooksコレクションの中から"Book1.xls"を指定することでWorkbookオブジェクトを取得し、
その参照を、オブジェクト変数wbに入れています。
そして、Nameプロパティで名前を取得してメッセージ出力しています。

プロパティとメソッドの違い

多少、余談になりますが、
プロパティとメソッドを、厳密に区分けする意味は特にあまりありません
プロパティは属性、メソッドは動作を与える。
そうは言っても、プロパティも値を設定する事で、動作を与えている事と変わりません。

最も端的な例としては、罫線を引く場合の、
.Bordersはプロパティ、.BorderAroundはメソッドですが、どちらも罫線が引かれます。

上記のプロパティ・メソッドの一覧の.Savedはプロパティですが、
.Saved = True
とすれば、保存済み状態にしている訳で、メソッドとの違いを認識しづらいと思います。
ただし、Savedでは実際に保存はされません。
実際に保存するにはSaveメソッドを実行します。

※要はエクセルを作った人が、どちらで作ったかの違いでしかありません。
従って、そのように分類されていて文法的な書き方に違いがある
そのくらいの解釈でとりあえずは十分でしょう。



同じテーマ「マクロVBA入門」の記事

第87回.WorksheetFunction(ワークシート関数を使う)
第51回.Withステートメント
第52回.オブジェクト変数とSetステートメント
第53回.Workbookオブジェクト
第54回.Windowsオブジェクト
第55回.Worksheetオブジェクト
第56回.Rangeオブジェクト(RangeとCells)
第57回.Applicationのプロパティ(マクロ高速化と警告停止等)
第58回.コレクションとは(Collection)
第59回.コレクション処理(For Each)
第60回.エラー処理(On Error)


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

変数を考えることはロジックを考える事|エクセル雑感(2021-04-11)
RangeオブジェクトのFor EachとAreasについて|VBA技術解説(2021-04-08)
PropertyのSetはLetでも良い|VBA技術解説(2021-03-31)
エクセル麻雀ミニゲーム|VBAサンプル集(2021-03-09)
VBA100本ノック 100本目:WEBから100本ノックのリストを取得|VBA練習問題(2021-03-03)
VBA100本ノック 魔球編:2桁の最小公倍数|VBA練習問題(2021-02-02)
Select Caseでの短絡評価(ショートサーキット)の使い方|VBA技術解説(2021-01-03)
VBA100本ノック 迷宮編:巡回セル問題|VBA練習問題(2020-12-31)
VBA100本ノック 魔球編:閉領域の塗り潰し|VBA練習問題(2020-12-16)
VBA100本ノック 魔球編:組み合わせ問題|VBA練習問題(2020-12-02)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.Excelショートカットキー一覧|Excelリファレンス
3.RangeとCellsの使い方|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.変数宣言のDimとデータ型|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.ひらがな⇔カタカナの変換|エクセル基本操作
8.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
9.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
10.セルに文字を入れるとは(Range,Value)|VBA入門




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


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



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