セレクトボックスを自動選択

今回は、セレクトボックスの選択です。
もう全然大丈夫という方もいらっしゃると思いますが、セレクトボックスはラジオボタン・チェックボックスのやり方とは少し異なるため注意が必要です。
こちらもいくつか制御方法がありますので解説していきます。

スポンサー リンク

フォームセレクトボックスの自動選択マクロ1

Sub sample()

  Dim objIE  As InternetExplorer
  Dim objInpSel As HTMLSelectElement
  
  'InternetExplorerでテスト用フォームページを起動
  Call ieView(objIE, "http://www.vba-ie.net/code/test.html")
  
  Set objInpSel = objIE.document.getElementsByName("pref")(0)

  'セレクトボックスを選択
  objInpSel.selectedIndex = 2

End Sub

※ドラッグ(スワイプ)すると全体を確認できます。

テスト用フォームページのソース

<form method="post" name ="form1" action="?">
出身地:
<select name="pref">
<option>東京</option>
<option>大阪</option>
<option>福岡</option>
</select>
(省略)
</form>

※必要な項目のみ抽出しています。

実行結果

VBAのIE制御でセレクトボックスを選択

name名に「pref」という名前のエレメントを取得し、「SelectedIndexプロパティ」で選択しています。
今回は、インデックス2番の福岡を選択しています。

objIE.document.getElementsByName("name名")(添え字).selectedIndex = インデックス番号

フォームセレクトボックスの自動選択マクロ2

Sub sample()

  Dim objIE  As InternetExplorer

  'InternetExplorerで本サイトを起動
  Call ieView(objIE, "http://www.vba-ie.net/code/test.html")

 'セレクトボックスを選択
 objIE.document.all("pref")(2).Selected = True

End Sub

※ドラッグ(スワイプ)すると全体を確認できます。

こちらでは、Allオブジェクトでprefエレメントを取得し、添え字2の福岡を選択しています。
よく、ラジオボックスなどと同じ処理でうまくいかないという方が多いですが、セレクトボックスは処理の仕方が違うということを覚えておきましょう。

次の「ファイル選択をクリック」の制御方法について解説していきます。

次の記事: VBAでIEのファイル選択をクリック >>

Excel VBAでIEを思いのままに操作できるプログラミング術 Excel 2013/2010/2007/2003対応

近田 伸矢, 植木 悠二, 上田 寛

IEのデータ収集&自動操作のプログラミング本はこの1冊だけ!IEの起動やポップアップウィンドウ、表示を制御する基本的なコードはもちろん、テキストボックスやラジオボタン、表、ハイパーリンクなどのHTML部品を制御する方法など、自動操作に欠かせないノウハウを丁寧に解説。

VBAのIE制御についてのQ&A掲示板

↑VBAのIE操作で分からない事があればこちらの掲示板よりご質問ください。

ExcelのVBA初心者入門

↑こちらはVBAをマスターできるよう初心者向けのエクセルVBA入門コンテンツになります。

目次

IE操作に便利なツール

こちらでは、これまでに紹介したIE(InternetExplorer)操作で便利な機能をツール化しています。無償でダウンロードできますので、目的に合わせたご利用ください。

IEのメソッド・プロパティ

こちらでは、IE(InternetExplorer)オブジェクトのメソッド・プロパティをまとめています。

IE操作のVBA関数

こちらでは、エクセルVBAのIE(InternetExplorer)操作で利用されたVBA関数をまとめています。

IE操作のステートメント

こちらでは、エクセルVBAのIE(InternetExplorer)操作で利用されたステートメントをまとめています。ExcelのVBAで基本的な部分になりますので、しっかり理解しましょう。

IE制御のVBAコード

こちらでは、これまでに作成したIE(InternetExplorer)操作で役立つサブルーチンをまとめています。
全てをコピーする必要はありませんが、目的に合わせたサブルーチンをご利用ください。