Selenium(Edge/Chrome)

SeleniumからEdge/Chromeが起動してもすぐ消えてしまう【ExcelVBA】

SeleniumからEdge/Chromeが起動してもすぐ消えてしまう

VBAでInternetExplorerを自動操作をしている場合にはなかった概念です。
ExcelVBAからIEを操作していても、自動でブラウザが閉じる事はありませんでした。

SeleniumBasicの場合は、条件によっては自動で閉じてしまう為、注意が必要です。
※初歩的なミスに注意。

Edge/Chromeが閉じてしまうサンプルコードと対策

違いはDim driver As New Selenium.WebDriverの宣言をプロシージャ内に宣言するかプロシージャ外に宣言するかだけです。

'■ブラウザがすぐ閉じてしまうパターン
Public Sub sample()
    Dim driver As New Selenium.WebDriver'★プロシージャ内に宣言
    '■chrome かEdgeどちらかを選択。
    driver.Start "chrome"
'   driver.Start "edge"
 
    '■HPを開く
    driver.Get "https://vba-create.jp"
End Sub

 

'■ブラウザが閉じないパターン
Dim driver As New Selenium.WebDriver'★プロシージャ外に宣言
Public Sub sample()
    '■chrome かEdgeどちらかを選択。
    driver.Start "chrome"
'   driver.Start "edge"
 
    '■HPを開く
    driver.Get "https://vba-create.jp"
        
End Sub

注意点

  • プロシージャ外に変数を出した場合、自動で閉じる事はありません。
    その為、ブラウザの起動→終了を繰り返し処理をする場合は、ブラウザを閉じる処理は入れましょう。

SeleniumBasicについて

Internet Explorer11 のサポート期限が2022年6月までと、スクレイピング自体入れ替えていく必要があります。
今一番スムーズなのはSeleniumBasicを使用したスクレイピングと考えます。

但し、VBAでのネット記事は少なく困っている方も多いと思います。
弊社で代行開発も可能ですので、お気軽にご用命ください。

コメント

タイトルとURLをコピーしました