前提・実現したいこと
職場で使用するシステムに(IE)にログインしボタンをボタンクリックをしたいです。
インナーフレームがあると思われアクセスできなかったため何度もトライして今の形となっております。
ログイン後のobjectが正しく取れてないと思われ、ボタンクリックまでいけない端末があり調べました。
そうするとobjIE.document.Titleができる端末とできない端末ではログイン前のタイトルになっており使えないようです。
しかしSleepなどを使用しても改善せず、
またステップインで確認すると正しくobjIE.document.Titleが遷移後の画面のもとを取得してくれており
行き詰っております。
■■な機能を実装中に以下のエラーメッセージが発生しました。
発生している問題・エラーメッセージ
エラーメッセージ ```Debug.Print objIE.document.Titleの時点でタイトルがログイン画面のdocumentを参照している状況から抜けれません。 実行時エラー438 オブジェクトはこのプロパティまたはメソッドをサポートしていません。となります。 ### 該当のソースコード Sub ログイン() Dim objIE As Object Dim htmlDoc As HTMLDocument 'HTMLドキュメントオブジェクトを準備 Set objIE = CreateObject("internetexplorer.application") 'New InternetExplorer objIE.Visible = True 'IEを表示 objIE.navigate "http://172.18.@@@@@@@@@@@@@@@@@@@@@@@" Call WaitIE(objIE) Set htmlDoc = objIE.document 'objIEで読み込まれているHTMLドキュメントをセット htmlDoc.getElementById("TxtUser").Value = "1243" 'ユーザーネーム htmlDoc.getElementById("TxtPass").Value = "12431243" 'パスワード htmlDoc.getElementById("BtnLogin").Click 'ログイン Set htmlDoc = Nothing 'ログインページのHTMLをいったん破棄 Call WaitIE(objIE) Debug.Print objIE.document.Title Set htmlDoc = objIE.document 'objIEで読み込まれているHTMLドキュメントをセット Set iframeDoc = htmlDoc.frames(1).document iframeDoc.getElementById("BtnSyukkin").Click End Sub Sub WaitIE(objIE As InternetExplorer) Do While objIE.Busy = True Or objIE.readyState <> 4 '読み込み待ち '4=READYSTATE_COMPLETE DoEvents Loop End Sub ### 試したこと wait IE でSleep を10sec追加しても変化がありませんでした。 ステップインでは成功します。 objIE.document.Titleができるときとできないときで違います。(ログイン前のタイトルかログイン後か) ### 補足情報(FW/ツールのバージョンなど) エクセル2013 ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。