第138回.外部ライブラリ(ActiveXオブジェクト)
VBAには外部ライブラリ(ActiveXオブジェクト)を操作する事が出来る仕組みがあります。
ActiveXオブジェクトとは、オートメーションをサポートするアプリケーションがオートメーションインターフェイスを通して他のアプリケーションに公開しているオブジェクトです。
VBAでは、このライブラリのオブジェクトを参照することでそのアプリケーションを操作できます。
つまり、そのアプリケーションがインストールされている必要があります。
例えば、Office製品のAccessがインストールされていなければ、AccessのActiveXオブジェクトは利用できません。
したがってマクロVBAの開発環境だけでなく、そのVBA実行環境にも当該アプリケーションがインストールされている必要があります。
良く使われる事の多いIEで使用するActiveXコントロールを指すものではありません。
事前バインディングと遅延バインディング(実行時バインディング)
事前バインディング
事前バインディングされたオブジェクトでは、アプリケーションが実行される前に、
コンパイラによってメモリの割り当てとその他の最適化が実行されます。
ただし、外部オブジェクトの場合は参照設定が必要になります。
遅延バインディング(実行時バインディング)
この型のオブジェクトは、任意のオブジェクトへの参照を保持できますが、
事前バインディングされたオブジェクトの利点をほとんど持ちません。
実装(VBA記述)の違い
Dim objFSO As Object
Set objFSO = CreateObject("Scripting.FileSystemObject")

※ライブラリ一覧はPC環境により変わります。
または、
Dim objFSO As FileSystemObject
Set objFSO = New FileSystemObject
変数宣言の型がObjectが遅延バインディング、特定のオブジェクト型が事前バインディング
事前バインディングと遅延バインディング(実行時バインディング)
参照設定する名前とCreateObject関数の引数文字列が違う為に書き換えに苦労する場合があります。
VBAで良くつかうオブジェクトを以下で一覧にしてしています。
参照設定、CreateObject、オブジェクト式の一覧
VBAで良く使われるライブラリ
「参照設定」のダイアログをみて分かる通り、以下はほんの一部です。
VBAで使えるライブラリは膨大な数が存在します。
Office製品
インターネット情報の取得
InternetExplorer
MSHTML
MSXML2
Selenium
それぞれ以下で解説しています。
メール送受信
ファイルシステムオブジェクト(FileSystemObject)
Dictionary(ディクショナリー)
正規表現(RegExp)
WshShell (Wscript.Shell)
Shell.Application
ADO(ActiveX Data Objects)
OLE DBをActiveXコントロールの形で使えるようにしたプログラミングインターフェースになります。
ActiveXオブジェクトの最後に
とはいえ頻繁に使うものは限られてきます。
ここで紹介したものは広く一般に使われているものです。
紹介したもの以外については、個別に書籍やWEBで調べながら使用してください。
ただし、ライブラリによっては情報が極めて少ないものもありますので、その点はご注意ください。
同じテーマ「マクロVBA入門」の記事
第125回.Worksheetのイベントプロシージャー
第130回.テーブル操作の概要(ListObject)
第131回.テーブル操作のVBAコード(ListObject,DataBodyRange)
第142回.テーブル全件処理とデータ最終行(ListObject,DataBodyRange)
第127回.他のブックのマクロを実行(Runメソッド)
第128回.マクロをショートカットで起動(OnKeyメソッド)
第129回.レジストリの操作(SaveSetting,GetSetting,GetAllSettings,DeleteSetting)
第133回.引数の数を可変にできるパラメーター配列(ParamArray)
第134回.Errオブジェクトとユーザー定義エラー
第138回.外部ライブラリ(ActiveXオブジェクト)
第140回.Property {Get|Let|Set} ステートメント
新着記事NEW ・・・新着記事一覧を見る
抜けている数値を探せ|エクセル雑感(2022-07-01)
.Net FrameworkのSystem.Collectionsを利用|VBA技術解説(2022-06-29)
迷路ネコが影分身の術を体得したら…|エクセル雑感(2022-06-27)
迷路にネコが挑戦したら、どうなるかな…|エクセル雑感(2022-06-26)
サロゲートペアに対応した自作関数(Len,Left,Mid,Right)|エクセル雑感(2022-06-24)
「マクロの登録」で登録できないプロシージャーは?|エクセル雑感(2022-06-23)
オブジェクトのByRef、ByVal、Variant|エクセル雑感(2022-06-22)
コメントから特定形式の年月を取り出す|エクセル雑感(2022-06-19)
4,9を使わない連番作成|エクセル雑感(2022-06-17)
連番を折り返して出力|エクセル雑感(2022-06-16)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Excelショートカットキー一覧|Excelリファレンス
7.マクロって何?VBAって何?|VBA入門
8.並べ替え(Sort)|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.エクセルVBAでのシート指定方法|VBA技術解説
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。