フォームクリック「formClick」の解説

今回は、チェックボックス・ラジオボタンの「クリック」についての解説です。
次回解説する送信・リセットなどとは別のやり方となります。
利用頻度の高さで言えば後者になりますが、formのサブルーチンということですので念のためご紹介します。
ただし、こちらの方がより確実な方法ですので、もし後者で対応できない場合は、こちらで処理をしましょう。

スポンサー リンク

フォームクリックのサブルーチン


Sub formClick(objIE As InternetExplorer, _
              nameValue As String, _
              tagValue As String)

 'form要素のクリック
 For Each objTag In objIE.document.getElementsByTagName("input")

  If objTag.Name = nameValue And objTag.Value = tagValue Then

   objTag.Click

   Exit For

  End If

 Next

End Sub

フォームクリックマクロ

Sub sample()

  Dim objIE  As InternetExplorer

  'テスト用フォームページを表示
  Call ieView(objIE, "http://www.vba-ie.net/code/test.html")

 '性別をクリック
 call formClick(objIE, "sex", "女")

 '好きな色をクリック
 call formClick(objIE, "lcolor", "赤")
 call formClick(objIE, "lcolor", "黄")

End Sub

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

<form method="post" name ="form1" action="?">
性別: <input type="radio" name="sex" value="男" checked="checked" /> 男 
<input type="radio" name="sex" value="女" /> 女
好きな色:
<input type="checkbox" name="lcolor" value="赤" /> 赤
<input type="checkbox" name="lcolor" value="青" /> 青
<input type="checkbox" name="lcolor" value="黄" /> 黄
(省略)
</form>

実行結果

formテキスト自動クリック

こちらの処理で「性別」「好きな色」を自動クリックします。
引数について以下の3つを設定しています。

引数名データ型内容値の事例初期値省略
objIEInternetExplorerIEオブジェクトobjIE,objIE2×
nameValueStringname属性の名前文字列"sex","lcolor"×
tagValueString目的エレメントのクリックする値文字列"女","赤","黄"×
formClick("IEオブジェクト","name属性の名前文字列","目的エレメントのクリックする値文字列")

こちらは、おなじみの内容です。
「objIE」はオブジェクトを入力します。
「Name」はname属性を値を入力します。
「tagValue」には、クリックする値を入力します。


For Each objTag In objIE.document.getElementsByTagName("input")
(省略)
Next

まずは、input要素を取得します。ここから1つずつループでデータをチェックしていく処理です。


If objTag.Name = Name And objTag.Value = tagValue Then
(省略)
End If

こちらでは、name属性とクリックする値が一致した場合に次の処理へ進む形になります。


objTag.Click

Clickメソッド」で該当するエレメントをクリックします。


Exit For

最後に処理が完了したので、ループから脱出します。

次回は「タグクリック」について解説していきます。

次の記事: VBAでIEのtagクリックサブルーチン化 >>

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

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

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

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

↑エクセルVBAのIE(InternetExplorer)操作で分からない事があればこちらの掲示板よりご質問ください^^

ExcelのVBA初心者入門

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

VBAのIE制御入門RSS

RSSフィードを登録すると最新記事を受け取ることができます。

VBAIE操作のスカイプレッスン

VBAでIE(InternetExplorer)制御の準備

【ダウンロード】IE操作に便利なツール

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

IEオブジェクトのメソッド・プロパティ

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

IE操作に利用されているVBA関数

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

IE操作に利用されているステートメント

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

IE(InternetExplorer)制御のVBAコード

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