第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入門」の記事
第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} ステートメント
第143回.WorksheetFunctionの効率的な使い方とスピル新関数の利用
新着記事NEW ・・・新着記事一覧を見る
シートコピー後のアクティブシートは何か|ツイッター出題回答 (2023-09-19)
Excel関数の引数を省略した場合について|ツイッター出題回答 (2023-09-14)
セル個数を返すRange.CountLargeプロパティとは|VBA技術解説(2023-09-08)
記号を繰り返してグラフ作成(10単位で折り返す)|ツイッター出題回答 (2023-08-28)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-08-24)
ランクによりボイントを付ける(同順位はポイントを分割)|ツイッター出題回答 (2023-08-22)
OneDrive使用時のThisWorkbook.Pathの扱い方|VBA技術解説(2023-07-26)
列幅不足による###表示や指数表示を判定する|VBA技術解説(2023-07-12)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-07-04)
シート関数のCOUNTIFS,SUMIFS,MAXIFSと同じ処理|Power Query(M言語)入門(2023-02-28)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.繰り返し処理(For Next)|VBA入門
4.変数宣言のDimとデータ型|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.マクロとは?VBAとは?VBAでできること|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.条件分岐(IF)|VBA入門
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。