ここから本文です

EXCELのVBAにてインターネットエクスプローラー(IE11)を立ち上げて操作するプログ...

kob********さん

2019/6/1009:48:38

EXCELのVBAにてインターネットエクスプローラー(IE11)を立ち上げて操作するプログラムを作成しました。
IEの所定のホームページ上表に数値を入力していくプログラムです。

このプログラムはMicrosoft Visual Basic for Applications画面を開いた状態で動作させると問題ないのですが、
開いていない場合、IEのアイコンが下部でオレンジ点滅するのみで次の動作に進みません。
どんなことが考えられるでしょうか。

以下のような書きだしでIEを開いています。

Sub SHNYUURYOKU()

Dim objIE
Dim objShell

Set objShell = CreateObject("Shell.application")
Set objIE = CreateObject("internetexplorer.application")
DoEvents
objIE.Visible = True
DoEvents
objIE.Navigate2 ("http://*省略*.htm")
DoEvents
Set objIE = Nothing
DoEvents
Set objIE = objShell.Windows.Item(objShell.Windows.Count - 1)
DoEvents
objIE.Visible = True

閲覧数:
28
回答数:
1
お礼:
500枚

違反報告

ベストアンサーに選ばれた回答

プロフィール画像

カテゴリマスター

hot********さん

2019/6/1010:18:26

普通のページを開くのには何も問題ないように見えます。
ただ最後の方の

>Set objIE = objShell.Windows.Item(objShell.Windows.Count - 1)

を見ると、別ウィンドウが開くページを処理しようとする場合、こんなプログラムになると思います。
と言う訳で、別ウィンドウを開くページを処理する場合です。


[ その1 ]

>objIE.Navigate2 ("http://www.google.com")

の後に

Application.Wait [Now()+"0:0:5"] '5秒待ち(秒数は加減してください)

を入れる。



[ その2 ]

>objIE.Navigate2 ("http://www.google.com")



Dim n As Integer
n = objShell.Windows.Count
objIE.Navigate2 ("http://www.google.com")
Do While n = objShell.Windows.Count: DoEvents: Loop

にする。

この回答は投票によってベストアンサーに選ばれました!

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる