VBAでEdge/Chromeを起動し、タブを移動したい場合があります。
以下で前後のタブに移動可能です。
- SwitchToPreviousWindowで一つ前のタブ
- SwitchToNextWindowで一つ後のタブ
- SwitchToWindowByTitleで任意のタブ(今回はこちらの記事)
Edge/Chromeで名前指定してタブ移動するサンプルコード
Dim driver As New Selenium.WebDriver
'■Edge/Chromeで指定したタイトルのタブに移動する
Public Sub sample()
'■ブラウザを起動
driver.Start "chrome" 'Edgeの場合はdriver.start "edge"
driver.Get "https://vba-create.jp/"
'■新しいタブを開く(弊社サイト/Yahoo/Googleのタブが立ち上がる)
driver.ExecuteScript ("window.open('https://www.yahoo.co.jp/')")
driver.ExecuteScript ("window.open('https://www.google.co.jp/')")
'■現在Seleniumで有効なURLがSwitchToWindowByTitleで移動するのがわかる。
Debug.Print driver.Url 'https://vba-create.jp/
driver.SwitchToWindowByTitle ("Yahoo! JAPAN")
Debug.Print driver.Url 'https://www.yahoo.co.jp/
'■タブが存在しないと実行時エラー発生。(完全一致でないとエラーが発生する)
driver.SwitchToWindowByTitle ("Yahoo")
'実行時エラー23
'NoSuchWindowError
'Window not found Yahoo
End Sub
注意点
- 同名タイトルのページが複数存在する場合は、先勝ちです。
- タイトル名は完全一致で指定する必要があります。※部分一致ではエラー発生します。
関連記事
SeleniumBasicについて
Internet Explorer11 のサポート期限が2022年6月までと、スクレイピング自体入れ替えていく必要があります。
今一番スムーズなのはSeleniumBasicを使用したスクレイピングと考えます。
但し、VBAでのネット記事は少なく困っている方も多いと思います。
弊社で代行開発も可能ですので、お気軽にご用命ください。



コメント