パスワードボックスに値を自動入力

今回は、フォームのパスワード入力について解説していきます。
もう解説なしに理解できる方も多いかと思いますが、「テキストボックスに値を入力」と同じ処理で行います。

スポンサー リンク

フォームパスワードボックスの自動入力マクロ1

Sub sample()

  Dim objIE  As InternetExplorer

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

 'パスワードボックスに値を入力
 objIE.document.GetElementsByName("pass")(0).value = "1234"

End Sub

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

<form method="post" name ="form1" action="?">
パスワード:<input type="password" name="pass" />
(省略)
</form>

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

実行結果

VBAのIE制御でパスワードボックスに値を入力

こちらは、「GetElementsByNameメソッド」を利用した値の入力方法です。
name名に「pass」という名前のエレメントを取得し、値を入力しています。

objIE.document.GetElementsByName("name名")(添え字).value = "入力する値"

ただし、1ページに複数のフォームが存在し、そのどちらにもname名にpassが設定されていた場合は、添え字でどちらのpassを指定しているのかを決めなければいけません。
ありえない話ですが、1ページに100のフォームが存在し、同じpassが使われていた場合は、該当するpassが何番目かチェックするのは非効率で手間がかかります。
今度は、Formを取得してからpassに値を入力する別の方法を解説していきます。

フォームパスワードボックスの自動入力マクロ2

Sub sample()

  Dim objIE  As InternetExplorer

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

 'パスワードボックスに値を入力
 objIE.document.forms("form1").pass.value = "1234"

End Sub

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

<form method="post" name ="form1" action="?">
パスワード:<input type="password" name="pass" />
(省略)
</form>

パスワードボックスですので、入力した値は見た目では分かりませんが、「1234」の数字が自動入力されています。
こちらは、まずname=form1に一致するフォームを取得します。
そのフォームの中にあるname=passのエレメントに対して値を入力しています。
この方法はピンポイントで入力する方法ですが、フォームにnameが設定されていない場合もありますので、その時は「objIE.document.forms(0).pass.value = "1234"」といったように添え字で対応していきます。
正しいマークアップをしているサイトであれば問題ありませんが、タグが抜けていたり、正しくないサイトも多く存在しますので、そこは内容を見極めながらどの方法が一番よいか考えてみてください。

次の「テキストエリアに値を入力」ではテキストエリアの入力について解説していきます。

次の記事: VBAでIEのテキストエリアに値を入力 >>

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)操作で役立つサブルーチンをまとめています。
全てをコピーする必要はありませんが、目的に合わせたサブルーチンをご利用ください。