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

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

ただいまの
回答率

88.92%

seleniumでchromeを動かしたい chrome driverがうまく動かない

受付中

回答 2

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 6,661

mush01

score 14

Seleniumでchromeを動かしたいのですが、うまくいきません。
おそらく、chrome driverの設定がうまくできていないことが原因だと思います。
safariはseleniumで操作することはできました。
環境
MacOS Mojave version 10.14.4
Chrome version = 74.0.3729.157
Chrome driver version =  74.0.3729.6
仮想環境を作ってその中で動かしています。
実行したコード

import time
from selenium import webdriver

driver = webdriver.Chrome('/Users/aaa/scraping')
driver.get('https://www.google.com/')
time.sleep(5)
search_box = driver.find_element_by_name("q")
search_box.send_keys('ChromeDriver')
search_box.submit()
time.sleep(5)
driver.quit()

エラー

Traceback (most recent call last):
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/common/service.py", line 76, in start
    stdin=PIPE)
  File "/usr/local/Cellar/python/3.7.3/Frameworks/Python.framework/Versions/3.7/lib/python3.7/subprocess.py", line 775, in __init__
    restore_signals, start_new_session)
  File "/usr/local/Cellar/python/3.7.3/Frameworks/Python.framework/Versions/3.7/lib/python3.7/subprocess.py", line 1522, in _execute_child
    raise child_exception_type(errno_num, err_msg, err_filename)
PermissionError: [Errno 13] Permission denied: '/Users/aaa/scraping'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "a.py", line 4, in <module>
    driver = webdriver.Chrome('/Users/aaa/scraping')
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/chrome/webdriver.py", line 73, in __init__
    self.service.start()
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/common/service.py", line 88, in start
    os.path.basename(self.path), self.start_error_message)
selenium.common.exceptions.WebDriverException: Message: 'scraping' executable may have wrong permissions. Please see https://sites.google.com/a/chromium.org/chromedriver/home

パスはたぶん通っていると思います。

(scraping) aaanoMBP:scraping aaa$ export -p

declare -x PATH="/Users/aaa/scraping/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/Users/aaa/scraping"
declare -x PWD="/Users/aaa/scraping"

以上です。
よろしくお願いいたします。

追記

driver = webdriver.Chrome('/Users/aaa/scraping/chromedriver')


に変更したところ

Traceback (most recent call last):
  File "a.py", line 4, in <module>
    driver = webdriver.Chrome('/Users/aaa/scraping/chromedriver')
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/chrome/webdriver.py", line 81, in __init__
    desired_capabilities=desired_capabilities)
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/remote/webdriver.py", line 157, in __init__
    self.start_session(capabilities, browser_profile)
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/remote/webdriver.py", line 252, in start_session
    response = self.execute(Command.NEW_SESSION, parameters)
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/remote/webdriver.py", line 321, in execute
    self.error_handler.check_response(response)
  File "/Users/aaa/scraping/lib/python3.7/site-packages/selenium/webdriver/remote/errorhandler.py", line 242, in check_response
    raise exception_class(message, screen, stacktrace)
selenium.common.exceptions.WebDriverException: Message: unknown error: cannot find Chrome binary
  (Driver info: chromedriver=74.0.3729.6 (255758eccf3d244491b8a1317aa76e1ce10d57e9-refs/branch-heads/3729@{#29}),platform=Mac OS X 10.14.4 x86_64)


というエラーになり、やはりうまくいかないです。

chromediverを開いてみたら

Only local connections are allowed.
Please protect ports used by ChromeDriver and related test frameworks to prevent access by malicious code.
[1558411773.099][SEVERE]: bind() failed: Address already in use (48)
IPv4 port not available.


と書かれており、IPv4 port not availableを検索してみたら、
https://yuichon.com/2019/03/ruby-commanderror/のBlogを見つけました。
もしかして自分も適当にchrome driverを配置した原因で、binがおかしくなったのかなと思いましたが、
ターミナルでpython -Vはしっかりと動きました。

IPv4 port not availableは関係あるでしょうか?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • can110

    2019/05/21 16:17

    その方法だと、単に絶対パスを作りこんでいるだけでなので、回答追記のように実行ファイルの存在確認をしてください。

    キャンセル

  • mush01

    2019/05/21 19:39

    返信有難うございます。
    import os
    path = '/Users/aaa/scraping/chromedriver'
    print( os.path.isfile(path))
    以下のコードを実行したらTrueになりました。
    それから、PhantomJSをchromedriverと同じディレクトリに配置し、
    PhantomJSに変えて実行したら、ちゃんと動いたので、やはり、chromedriverに何かしら問題があるではないかと考えています。

    キャンセル

  • can110

    2019/05/22 07:28

    追記の「cannot find Chrome binary」エラーより、Chromeブラウザを探しきれていないようです。
    Google Chrome(と念のためChromeDriver)の再インストールを試してみてはいかがでしょうか?

    キャンセル

回答 2

0

driver = webdriver.Chrome('/Users/aaa/scraping')

提示エラーPermissionError: [Errno 13] Permission denied:より推測すると
このパスはChromeDriverのあるディレクトリのパスではないでしょうか?

chromedriverのパスが不明なので確実なことは云えませんが、たとえば/Users/aaa/scraping/bin/chromedriverのように実行ファイル名のフルパスを渡してください。

なお、ファイルの存在確認は以下のようなコードでできます。

import os
path = '/path/to/chromedriver'
print( os.path.isfile(path))

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

前提条件の確認

仮想環境を作ってその中で動かしています。

仮想環境とは何のことですか? Google Chrome はその仮想環境にもインストールしてありますか? 作業はすべて仮想環境で行いましたか?

ドキュメントに従う

エラーメッセージのいうようにドキュメントを読んでやり直してみてはいかがでしょうか。

Getting started with ChromeDriver on Desktop https://sites.google.com/a/chromium.org/chromedriver/getting-started より

Ensure Chromium/Google Chrome is installed in a recognized location

Chrome がデフォルトの場所にインストールされているか確かめる。

Download the ChromeDriver binary for your platform under the downloads section of this site

プラットフォームにあった ChromeDriver 実行ファイルをダウンロードする。

Help WebDriver find the downloaded ChromeDriver executable

WebDriver が ChromeDriver 実行ファイルを見つけられるようにする(webdriver.Chrome() の引数を修正したのでこれはできているはず)。

ほかにも一通り目を通したらいいと思います。

以上の手順とは関係ないが、Address already in use について

[1558677843.232][SEVERE]: bind() failed: Address already in use (48)
IPv4 port not available. Exiting...

のようなメッセージが出て chromedriver がすぐ終了してしまった場合は TCP 9515 ポートがすでに使われています。別のところで chromedriver を実行していてそれが終了されていないとかの場合はそれらの chromedriver を終了してください。
netstat -f inet -anv コマンドで 127.0.0.1.9515 を LISTEN しているプロセスがいないことを確認してください。

Active Internet connections (including servers)
Proto Recv-Q Send-Q  Local Address          Foreign Address        (state)     rhiwat shiwat    pid   epid
tcp4       0      0  127.0.0.1.9515         *.*                    LISTEN      131072 131072   1591      0

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る