質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

1回答

1856閲覧

Excel VBA で、検索結果の上位10件のサイトをIEのタブで表示させたい。

max222

総合スコア12

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2019/03/19 05:35

Excel VBA で、検索結果の上位10件のサイトをIEのタブで表示させたい。

Excel VBA 初心者です。
例えば、セル【B4~B13】に検索ワードがあり、VBAで、それぞれの検索ワードでIEを立ち上げ
グーグルで、検索を掛けます。

ここまではできました。
その後、検索結果として表示された上位10件(上から10番目)までを、上記でたちあげた、
それぞれのIE上で、タブで分けて表示させたいです。

色々と、ググってはみましたが、自分が望むものはHitしませんでした。
(理解できていないだけかもしれません。。。)
本来、自分のVBAレベルではIE制御はまだまだ先なのですが、業務上どうしても必要で
他に分かる社内の人間もおりません。ご教示いただけると幸いです。

下記に記載した内容が、現段階のものです。
─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─
Sub 検索()

n = Cells(Rows.Count, "A").End(xlUp).Row
For iii = 4 To n
Range("B" & iii).Select
Dim ie As Object

Set ie = CreateObject("InternetExplorer.Application")
ie.Visible = True

'▼ ""で囲まれたURLの画面へ移動 ▼ ie.Navigate "http://www.google.co.jp/search?q=" & ActiveCell

waitNavigation ie

Next
End Sub
─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─
'▼ URL画面の読み込み待ち ▼
Sub waitNavigation(ie As Object)

Do While ie.Busy Or ie.ReadyState < 4
DoEvents
Loop
End Sub

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

stdio

2019/03/19 05:45

HTMLが取得できるなら直接書き換えれば済む話ですが... それば出来ないのでしょうか?
max222

2019/03/19 08:28

ご質問ありがとうございます。。。ありがとうございます…なんですが、自分の知識が着いていけておらず、そのご質問の意味さえ分かっておりません。orz 質問の意味としては、 A:Firefoxでhtmlの要素を確認し、googleの検索結果画面のhtml要素を確認し、上位10件を取得する。的なことでしょうか?  ↑そうであったり、仮に近しいやり方だった場合、その対応方法がわかりません。。。 B:webクエリで、一度Excelで読み込んで、その該当URLをIEタブで開くという事でしょうか?
stdio

2019/03/20 00:40

URLをIEタブで開かなくてもHTMLの文字列さえ取得できれば、後はSplit関数を使いまくって文字区切れば? そうしたら上位10位はすぐ取得できますが... しかし、基本的にランキングの様なシステムはPHPやjavascriptを使用している事が多いためもしかしたら、取得できないかも。 下記等を参考にしてみてはいかがでしょうか? https://tonari-it.com/vba-ie-get-table/ https://www.fastclassinfo.com/entry/vba_ie_control
guest

回答1

0

回答ではなくてヒント?ですみません。
また、「上位10件」ではなく、「検索結果の最初のページにヒットしたものだけ」の処理です。
「動画」とか「画像」みたいなのが一番上に表示されてしまっている場合はその部分は無視しています。

私もよくわかってないのですみませんが、当方でも色々試してみましたら、以降のコードで、一応、検索結果のタイトルとURLが取得できました。Excelのアクティブシートに書き出しています。

条件分岐の中で、「anc_anchor01.Click」みたいな感じで「Clickメソッド」を使うと、そのページへ飛ぶこともできます。ただ、別のタブに表示する方法がわかりませんでした。
「InternetExplorer getelementsbytagname 使い方」みたいな感じでWeb検索したら、もしかしたら、何か出てくるかもしれません。
あと、「<h3」という<h3>タグの一部があったら、タイトルを取得しているようにしていますが、これはHTMLソースを見たら、たまたまGoogleがh3を使っていたようなのでそうしました。なのでほかのタグが使われているページでは正常動作しないと思います。つまり、「<h3」だけでなく「<h2」なども分岐に加えたほうがいいかもしれません。(私もHTMLタグは詳しくないのでよくわかっていません!すみません!)

実行するには、VBEの画面にて、「Microsoft Internet Controls」と、「Microsoft HTML Object Library」を参照設定してからにします。
また、参照設定(事前バインディング)をしたので、IEのインスタンスの生成は、CreateObjectではなく、Newに変えました。
(参照設定して、CreateObjectしてしまうと2重になってしまうかもしれないので。また、インテリセンスが使いたかったので。)

もちろん、参照設定しないなら、Newではなく、CreateObject に戻してください。
「Microsoft HTML Object Library」がらみのものについても、CreateObject のようなことが必要だと思います。

ちゃんと動かなかったらごめんなさい。

VBA

1 2 3Sub test01() 4 5 Dim ie As InternetExplorer 6 Dim hd_htdoc As HTMLDocument 7 Dim anc_anchor01 As HTMLAnchorElement 8 Dim i As Integer 9 Dim s_HTML As String 10 Dim s_txt As String 11 12 Set ie = New InternetExplorer 13 ie.Visible = True 14 15 ie.Navigate "http://www.google.co.jp/search?q=" & "steve gadd" 16 waitNavigation ie 17 18 19 Set hd_htdoc = ie.Document 20 21 i = 1 22 23 'HTMLソースの中の、「<A>タグの部分」を総ざらいします。 24 For Each anc_anchor01 In hd_htdoc.getElementsByTagName("A") 25 26 '「anc_anchor01.outerHTML」の中に、 27 '「<h3」という<h3>タグの一部があったら、 28 '検索結果の中のタイトルを取得できるっぽいので 29 '以下の処理。 30 31 'ヒットした各Webページの部分の、 32 'タイトルやらURLやタグやら全部を変数に代入 33 s_HTML = anc_anchor01.outerHTML 34 35 If 0 < InStr(1, s_HTML, "<h3", vbBinaryCompare) Then 36 37 'ヒットした各Webページのタイトル部分のみを変数に代入 38 s_txt = anc_anchor01.outerText 39 40 'anc_anchor01.outerText(ヒットしたタイトル) の中に 41 '「改行」がいくつか含まれてしまっていたので "--" に置換して消す。 42 Range("A" & i) = Replace(s_txt, vbCrLf, "--", , , vbBinaryCompare) 43 Range("B" & i) = anc_anchor01.href 44 45 i = i + 1 46 47 Else 48 49 50 End If 51 52 53 Next anc_anchor01 54 55 56 57End Sub 58 59 60 61'▼ URL画面の読み込み待ち ▼ 62Sub waitNavigation(ie As Object) 63 64 Do While ie.Busy Or ie.ReadyState < 4 65 DoEvents 66 Loop 67 68End Sub 69 70

たまたま家に「ExcelVBA IE を思いのままに操作できるプログラミング術」という本が読まずに置いてあったので、それの一部を少し読んでみたら、なんとかやれました。
ただ、結局本を読んでもあまりよくわからず、でも「参照設定」して変数を決め打ちすればインテリセンスが使えるので、それと、HTMLソースを見てなんとかやってみただけなので、本当はもっとちゃんとしたコードがあるようにも思います。

IEの操作はそういった本を1冊買っておいた方が早いかもしれません。

※追記
今、この本、ちゃんと最後までさらーっと読み直してみたら、すごくよさそうです。今後ももしIE操作を細かく自動化したかったら、買っておいても損はないかもです。
著者のサイト?かは不明ですが、以下のサイトもよさげです。本に書いてることよりも詳しい説明も載っていました。(本書にもこのようなことが書かれています。本から入った方がわかりやすいと思います。)
https://www.vba-ie.net/sp/element/getelementsbytagname.php
各Tipsの目次らしきページ→ https://www.vba-ie.net/qanda/qanda.cgi

投稿2019/03/21 03:28

編集2019/03/22 16:47
komugi3333

総合スコア94

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問