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

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

第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.xls")
MsgBox wb.Name

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

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

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

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

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

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



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

第50回.総合練習問題6
第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 ・・・新着記事一覧を見る

VBAにおける変数のメモリアドレスについて|VBA技術解説(11月8日)
空文字列の扱い方と処理速度について(""とvbNullString)|VBA技術解説(1月7日)
Errオブジェクトとユーザー定義エラー|VBA入門(11月5日)
シングルクォートの削除とコピー(PrefixCharacter)|VBA技術解説(11月4日)
ユーザー定義型の制限とクラスとの使い分け|VBA技術解説(11月3日)
クリップボードに2次元配列を作成してシートに貼り付ける|VBA技術解説(11月1日)
VBAクラスを使ったイベント作成(Event,RaiseEvent,WithEvents)|VBA技術解説(10月31日)
VBAクラスのAttributeについて(既定メンバーとFor Each)|VBA技術解説(10月19日)
VBAの用語について:ステートメントとは|VBA技術解説(10月16日)
VBAのマルチステートメント(複数のステートメントを同じ行に)|VBA技術解説(10月14日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.変数宣言のDimとデータ型|ExcelマクロVBA入門
6.繰り返し処理(For Next)|ExcelマクロVBA入門
7.マクロって何?VBAって何?|ExcelマクロVBA入門
8.ひらがな⇔カタカナの変換|エクセル基本操作
9.空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)|VBA技術解説
10.セルに文字を入れるとは(Range,Value)|VBA入門



  • >
  • >
  • >
  • Workbookオブジェクト

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


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




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