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

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

新規登録して質問してみよう
ただいま回答率
85.37%
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

Q&A

1回答

14972閲覧

「unknown error: DevToolsActivePort file doesn't exist」を解決したい

Rank0.5

総合スコア0

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

0グッド

0クリップ

投稿2022/12/16 11:29

編集2022/12/25 14:44

実現したいこと

selenium + python で Google にログインした状態で Google chromeを立ち上げて、Youtubeを開こうとしています。

発生している問題

現時点でアカウントへのログインまでは成功しています。
ただ、以下のエラーが出て、driver.get("https:XXX")の箇所が実行されません。

エラーメッセージ

既存のブラウザ セッションで開いています。 Traceback (most recent call last): File "E:\Python\YoutubeStart\youtubelist_Start.py", line 14, in <module> driver = webdriver.Chrome(options=options) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "C:\Users\UserName\AppData\Local\Programs\Python\Python311\Lib\site-packages\selenium\webdriver\chrome\webdriver.py", line 81, in __init__ super().__init__( File "C:\Users\UserName\AppData\Local\Programs\Python\Python311\Lib\site-packages\selenium\webdriver\chromium\webdriver.py", line 106, in __init__ super().__init__( File "C:\Users\UserName\AppData\Local\Programs\Python\Python311\Lib\site-packages\selenium\webdriver\remote\webdriver.py", line 288, in __init__ self.start_session(capabilities, browser_profile) File "C:\Users\UserName\AppData\Local\Programs\Python\Python311\Lib\site-packages\selenium\webdriver\remote\webdriver.py", line 381, in start_session response = self.execute(Command.NEW_SESSION, parameters) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "C:\Users\UserName\AppData\Local\Programs\Python\Python311\Lib\site-packages\selenium\webdriver\remote\webdriver.py", line 444, in execute self.error_handler.check_response(response) File "C:\Users\UserName\AppData\Local\Programs\Python\Python311\Lib\site-packages\selenium\webdriver\remote\errorhandler.py", line 249, in check_response raise exception_class(message, screen, stacktrace) selenium.common.exceptions.WebDriverException: Message: unknown error: Chrome failed to start: exited normally. (unknown error: DevToolsActivePort file doesn't exist) (The process started from chrome location C:\Program Files (x86)\Google\Chrome\Application\chrome.exe is no longer running, so ChromeDriver is assuming that Chrome has crashed.) Stacktrace: Backtrace: (No symbol) [0x0042F243] (No symbol) [0x003B7FD1] (No symbol) [0x002AD04D] (No symbol) [0x002CC24E] (No symbol) [0x002C82E9] (No symbol) [0x002FF056] (No symbol) [0x002FEB2A] (No symbol) [0x002F8386] (No symbol) [0x002D163C] (No symbol) [0x002D269D] GetHandleVerifier [0x006C9A22+2655074] GetHandleVerifier [0x006BCA24+2601828] GetHandleVerifier [0x004D8C0A+619850] GetHandleVerifier [0x004D7830+614768] (No symbol) [0x003C05FC] (No symbol) [0x003C5968] (No symbol) [0x003C5A55] (No symbol) [0x003D051B] BaseThreadInitThunk [0x7594FEF9+25] RtlGetAppContainerNamedObjectPath [0x77AD7BBE+286] RtlGetAppContainerNamedObjectPath [0x77AD7B8E+238]

該当のソースコード

from selenium import webdriver from selenium.webdriver.chrome.options import Options #引数 userDir = r'C:\\Users\\UserName\\AppData\\Local\\Google\\Chrome\\User Data' profileDir = 'Default' options = Options() options.binary_location = "C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe" options.add_argument('--user-data-dir=' + userDir) options.add_argument('--profile-directory=' + profileDir) driver = webdriver.Chrome(options=options) driver.get("https://www.youtube.com")

試したこと

  • webdriver_managerの利用
    ⇒変化なし
  • セキュリティソフトのファイアウォール無効
    ⇒変化なし
  • リストオプション「--remote-debugging-port」でのポート設定
    ⇒エラー内容が "chrome not reachable" に変化
  • userDirを r'C:\Users\UserName\AppData\Local\Google\Chrome\User Data' にするも変化なし
  • '--profile-directory='でのプロファイル設定をやめ、
    '--user-data-dir=' に r'C:\Users\UserName\AppData\Local\Google\Chrome\User Data\Default' を指定したところ、プロファイルデータが呼び出せず、ログインしていない状態で表示されました。
  • Chromedriver.exeへのパスを追加
    ⇒変化なし

補足情報(FW/ツールのバージョンなど)

Windows 10 Home
Python3.11
Google Chrome 108.0.5359.125
ChromeDriver 108.0.5359.71
selenium 4.7.2

他知りたい情報等ありましたらお伝えください。
以上、よろしくお願いします。

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

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

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

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

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

guest

回答1

0

更新された回答

options.add_argument("--profile-directory=" + profileDir) という引数でデフォルトのユーザープロファイルを指定しているのが原因かもしれません。
この行を削除して実行してみたところ、問題なく動きました。

以下、手元の環境で正常に動いたコードです。

python

1import time 2 3from selenium import webdriver 4from selenium.webdriver.chrome.service import Service 5 6userDir = "C:\\Users\\User\\AppData\\Local\\Google\\Chrome\\User Data" 7 8options = webdriver.ChromeOptions() 9options.binary_location("C:\\Program Files\\Google\\Chrome\\chrome.exe") 10options.add_argument("--user-data-dir=" + userDir) 11 12service = Service( 13 executable_path="C:Users\\User\\scoop\\apps\\chromedriver\\current\\chromedriver.exe", 14 ) 15driver = webdriver.Chrome(service=service, options=options) 16 17driver.get("https://www.youtube.com/") 18 19time.sleep(10) 20 21driver.quit()

当初の回答

このエラーは大体、オプションが正確に読み込めなかった(指定している内容が間違っている)場合に起きるようです。

今回は、userDir = r'C:\\Users\\UserName\\AppData\\Local\\Google\\Chrome\\User Data' が問題です。

バックスラッシュを 2 つ重ねてエスケープしているにも関わらず、r を付けてそのエスケープを再度打ち消しています。つまり、パスが正確に読み込めなかったせいで Chrome の起動に失敗してます。

投稿2022/12/22 22:25

編集2022/12/25 16:47
Demerara

総合スコア397

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

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

Rank0.5

2022/12/24 16:48

申し訳ございません。現時点で既にログインまでは成功しているため、そこが原因ではないと思われます。
Demerara

2022/12/25 01:57

ログインした状態で起動しているのではないのですか? それに、 > selenium.common.exceptions.WebDriverException: Message: unknown error: Chrome failed to start: exited normally. と、あるように確かに Chrome の起動に失敗してます。 とはいえこれが原因でなければ、`chromedriver.exe` が指定されてないことが原因かもしれません。 ```python service = Service(executable_path="chromedriver.exeへのパス") webdriver.Chrome(service=service, options=options) ``` のように、`chromedriver.exe` へのパスを設定して動かしてみてください。
Rank0.5

2022/12/25 14:47 編集

>ログインした状態で起動しているのではないのですか? その通りです。ログイン自体は成功した状態でウィンドウは開いているため、profileDirまでは取得できているものと思われます。 一応、バックスラッシュを消して再実行しましたが、エラーに変化はありませんでした。 >とはいえこれが原因でなければ、`chromedriver.exe` が指定されてないことが原因かもしれません。 こちらも確認しましたが、エラー内容に変化はありませんでした。
Demerara

2022/12/25 16:18 編集

なるほど、少し勘違いをしていたかもしれません。 Chrome 自体は開いているが目的のアドレスが開けずに処理が停止してしまい、コンソールには上記のエラー文が出力されている状態ということですね。 ちなみに、"C:\\Users\\UserName\\AppData\\Local\\Google\\Chrome" に、"DevToolsActivePort" というファイルは存在していますか? もう一つ、"C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe" は間違いなく存在していますか? 32bit 版をインストールしているようですが、立ち上がっている Chrome.exe も間違いなく 32bit 版でしょうか?手元の環境では、64bit 版がインストールされ、"C:\\Program Files\\Google\\Chrome\\Application\\chrome.exe" に実行ファイルが存在します。そちらも一応確認して頂けますか?
Demerara

2022/12/25 16:48

回答を更新させて頂きました。検証のほどよろしくお願いいたします。
Rank0.5

2022/12/26 13:33

ありがとうございます。 以下、検証結果になります。 >Chrome 自体は開いているが目的のアドレスが開けずに処理が停止してしまい、コンソールには上記のエラー文が出力されている状態ということですね。 はい。その通りです。 >"C:\\Users\\UserName\\AppData\\Local\\Google\\Chrome" に、"DevToolsActivePort" というファイルは存在していますか? いいえ、ありませんでした。 >"C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe" は間違いなく存在していますか? 使用しているChromeは64bit版です。ですが、配置されているフォルダはProgram Files (x86)配下のフォルダです。これは、Ver.84以前のChromeの仕様の名残のようです。
Demerara

2022/12/26 13:54

確認ありがとうございます。恐らく、Chrome のデータファイルに欠損がある可能性があります。 現在使用している Chrome をアンインストールし、再度まっさらな Chrome をインストールして試して頂くことは可能でしょうか? その際、"~\AppData\Local\Google\Chrome" および、"~\AppData\Roaming\Google\Chrome" のフォルダを削除してください。万が一、"Program Files (x86)" 内に Chrome 関連のフォルダーがあればそれも削除してください。 必ず必要な情報はバックアップを取った上で、アンインストールを実行してください。ブラウザ上に保存しているパスワード等も全て消えます。最低限 "~\Local\Google\Chrome\User Data" だけでもバックアップを取っておくことを強くおすすめします。 パスワード含め、拡張機能やブックマーク等もブラウザからエクスポートできます。詳しくは、Google 等で検索してください。
Rank0.5

2022/12/27 11:53

Chromeをアンインストールし、関連フォルダを確認し、その後再インストールしました。 しかし、エラーに変化はありませんでした。
Demerara

2022/12/27 12:29

では、純粋に PowerShell で、次のようにコマンドを打って想定通りの挙動をするか確認してみてください。 ```powershell & 'C:\Program Files\Google\Chrome\Application\chrome.exe' --user-data-dir="C:\Users\UserName\AppData\Local\Google\Chrome\User Data" --profile-directory="Default" ```
Rank0.5

2022/12/27 16:54

上記のとおりPowerShellで実行すると、想定通りログインした状態のChromeが開きました。
Demerara

2022/12/28 11:16

となるとパスに間違いはないですね。 コードを実行する環境で、`python --version` とした際、3.11 が表示されますか? 同じく `pip show selenium` とした際に、selenium 4.7.2 が表示されますか? 両方の条件が満たされた環境で再度、以下のコードを実行してみて頂けますか?少し手直しを入れました。 裏で Chrome 関連のプロセスが走ってないか確認し、もし走っていれば関連タスクを終了させておいてください。Crash Handler 等が終了せずに残っていたり、Software Repair Tool のようなタスクも動いてたりします。 ```python import time from selenium import webdriver from selenium.webdriver.chrome.service import Service # ユーザープロファイルの保管場所 PROFILE_PATH: str = ( "C:\\Users\\User\\AppData\\Local\\Google\\Chrome\\User Data" ) # プロファイルの名前 PROFILE_DIR: str = "Default" # Chrome 専用のオプション options = webdriver.ChromeOptions() options.add_argument(f"user-data-dir={PROFILE_PATH}") options.add_argument(f"profile-directory={PROFILE_DIR}") service = Service( # chromedriver のパス executable_path="chromedriver.exe", ) # ドライバーの作成 try: driver = webdriver.Chrome(service=service, options=options) except Exception as e: print(f"[Error]: {e}") raise else: driver.get("https://www.youtube.com/") time.sleep(5) print(driver.title) time.sleep(5) driver.quit() ```
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問