Selenium(Edge/Chrome)

普段使用しているブラウザを起動しようとするとエラー発生する【Selenium】【ExcelVBA】

AddArgumentで"--user-data-dir="を利用して、普段使用しているブラウザを起動する場合、
VBAからChromeを起動する前に、手動でChromeを起動しているとエラーが発生し起動できません。

エラー内容

invalid argument: user data directory is already in use, please specify a unique value for --user-data-dir argument, or don't use --user-data-dir

既に指定したプロファイルを利用したChromeが立ち上がっているため、使えません。

エラーが発生するサンプルコード

Dim driver As New Selenium.WebDriver

'■普段使用しているChromeを起動する
Public Sub sample()
    '■事前に手動で下記プロファイルパスを利用したChromeを起動しておきます。
    '■プロファイルパスを指定 'chrome://versionで確認可能
    Dim str As String: str = "C:\Users\" & Environ("USERNAME") & "\AppData\Local\Google\Chrome\User Data"
    driver.AddArgument ("--user-data-dir=" & str)
    
    '■ブラウザを起動
    driver.Start "chrome"
    driver.Get "https://vba-create.jp/"
   
End Sub


問題解決方法

  • 新規でSelenium用のプロファイルを作成します。
    ”C:\Users\" & Environ("USERNAME") & "\AppData\Local\Google\Chrome\User Data"を
    "C:\Users\" & Environ("USERNAME") & "\AppData\Local\Google\Chrome\User Data2"などに変更すればdriver起動時に作成します。

関連記事

SeleniumBasicについて

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

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

コメント

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