三流君 ken3のmemo置き場

メモ置き場、保管庫として利用。まとまっていませんがヨロシク

挨拶・自己紹介:
失敗続きのAB型の変わり者 :三流プログラマー Ken3です
フリーのエンジニア・個人事業主です・・と書くと聞こえはイイが(それとなくカッコよく聞こえるが)、 現在は小さな案件の受注請負 と 短期派遣 で 日々つつましく?ほそぼそと暮らしてます。
(※詳細は[三流君 三流プログラマーとは?]を見てください)


広告:


[記事一覧、バックナンバーを見る]

XXXXXさんへ If TypeName(objWindow.document) = "HTMLDocument" のチェックを残してみては?

下記の質問をいただきました。

JRAのホームページをボタンを押しながら画面を切り替えていこうとおもい、
次のken3の方法で実行しましたが、Title名がどのページも同じで、うまく切り替わってくれません。
そこで、「****」以下の方法でbodyから一意の文字列検索をしようとしましたが
「strTemp = objWindow.document.body.innertext」部分でエラーとなります。
各ページのTitle名が同じ場合の画面の切り替えについて、教えてください。

''-------------------------------------------
'TypeNameでオブジェクト変数のタイプを表示する
Debug.Print "タイプは:" & TypeName(objWindow.document)
'HTMLDocumentだったら
' If TypeName(objWindow.document) = "HTMLDocument" Then
'URLとタイトルを表示する
' Debug.Print "タイトル:" & objWindow.Document.Title
' Debug.Print "URL:" & objWindow.Document.Url
' If objWindow.Document.Url = "https://mobile.rakuten-sec.co.jp/login.do" Then '指定したURLか?
' If objWindow.document.Title = "JRAホームページ" Then '指定したURLか?
''-----------------------------------------------
'*************************************************

'シェルのオブジェクトを作成する
Set objShell = CreateObject("Shell.Application")

'ウインドウの数だけまわすぞ
For Each objWindow In objShell.Windows
strTemp = ""

strTemp = objWindow.document.body.innertext

' strTemp = objWindow.document.getElementsByTagName("div").innertext
If InStr(strTemp, "開催のボタン") > 0 Then 'HTML文字列の中から見つけたら

Set objIE = objWindow '代入する


Exit For '見つけたのでループを抜ける

End If


Next
Set objShell = Nothing

上記質問に対して、

エラーの原因はよくわからないので、なんとも言えませんが、
私の過去記事
ken3memo.hatenablog.com
ken3memo.hatenablog.com
ken3memo.hatenablog.com
を見ると、

        'HTMLDocumentだったら
'        If TypeName(objWindow.document) = "HTMLDocument" Then

のコメントで未処理の部分
HTMLDocument
かチェックをしていないと、
IE以外のファイルエクスプローラなどが見つかると
strTemp = objWindow.document.body.innertext

.document.body. なんてないよ・・・とエラーが発生 怒られるかもしれません

勝手な予想です。






原因を勝手に決めつけたので、
対策は、
IEブラウザ か ファイルエクスプローラ
チェックするために
If TypeName(objWindow.document) = "HTMLDocument" のチェックを残してみては?

    'シェルのオブジェクトを作成する
    Set objShell = CreateObject("Shell.Application")
    
    'ウインドウの数だけまわすぞ
    For Each objWindow In objShell.Windows
        If TypeName(objWindow.document) = "HTMLDocument" Then '↓HTML IEの時だけチェックする

            strTemp = ""
            
            strTemp = objWindow.document.body.innertext
            msgbox strTemp            
    
'             strTemp = objWindow.document.getElementsByTagName("div").innertext
            If InStr(strTemp, "開催のボタン") > 0 Then 'HTML文字列の中から見つけたら
                
                Set objIE = objWindow   '代入する
                
                
                Exit For  '見つけたのでループを抜ける

            End If

       End If  '↑HTML IEの時だけチェックする
    
    Next

みたいに、
If TypeName(objWindow.document) = "HTMLDocument" のチェックを残してみては?

解決の糸口となれば幸いです。  三流プログラマー Ken3




三流君へ メッセージを送る

全ての質問に答えることはできませんが、
ダメもとで、気軽に質問、感想、メッセージを送ってくださいね・・・

感想や質問・要望・苦情など 三流君へメッセージを送る。
下記のフォームからメッセージを送ることができます。


あなたのお名前(ニックネーム):さん
返信は?:

アドレス:に返事をもらいたい
感想や質問↓:


(感想や質問・要望・苦情はHPで記事に載せることがあります。)
例:[XXXXさんへ回答例]←みたいに回答していたり...


Ken3 ホームページ 目次

分類:HPを大きく分けると4つの柱(分類)です。
・[Excel/Access VBA]の解説
・[ASP(Active Server Pages)]の解説。
・[元コンビニ店長時代の話]が弟に巻き込まれ、失敗した脱サラ、畑違い?の仕事で失敗。
・[プログラマーの愚痴]では、あまり見せたくない三流プログラマーの内面かな。
三流君を踏み台にする
主に上記4つの分類でHP作成やメルマガの発行を行ってます。
※更新頻度が落ちていて情報の鮮度が悪いです。

三流解説動画の再生リスト
https://www.youtube.com/user/ken3video/playlists

本当に三流なんです(笑):たまにスゴイですねなんて言われることもありますが、
真実は→ [三流君の真実は...] ←を初めに見てくださるとわかると思います。
(からくりは、成功例↑しか載せてなくて ヒドイ失敗例はお蔵入り迷宮入りが多かったりします)