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

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

ただいまの
回答率

87.78%

javascript:void(0)をPythonのseleniumでクリックしたい

受付中

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,319

score 0

前提・実現したいこと

Python3でSeleniumを利用しています。
javascript:void(0)で設定しているimgボタンをクリックし、ポップアップを表示させたい。

実装されているHTML(クリックしたい個所)

<a href="javascript:void(0)"><img src="https://hoge/images/btn/cart.gif?magic=**********" class="btn" id="to_cart" /></a>

試したこと

1  <a href="javascript:void(0)"> のXPathを取得しクリックしようとする。

driver.find_element_by_xpath('//*[@id="centerCol"]/div[1]/div[4]/div[2]/a[2]').click()

2  <img src="https://hoge/images/btn/cart.gif?magic=******" class="btn" id="to_cart" /> のXPathを取得しクリックしようとする。

driver.find_element_by_xpath('//*[@id="to_cart"]').click()

3  id="to_cart" のidを指定しクリックしようとする。

driver.find_element_by_id(to_cart).click()

発生している問題・エラーメッセージ

【 1 の場合のエラー】

Traceback (most recent call last):
  File "C:\Users\test\Desktop\Python\Selenium\test.py", line 61, in <module>
    driver.find_element_by_xpath('//*[@id="centerCol"]/div[1]/div[4]/div[2]/a[2]').click()
  File "C:\python\lib\site-packages\selenium\webdriver\remote\webelement.py", line 80, in click
    self._execute(Command.CLICK_ELEMENT)
  File "C:\python\lib\site-packages\selenium\webdriver\remote\webelement.py", line 633, in _execute
    return self._parent.execute(command, params)
  File "C:\python\lib\site-packages\selenium\webdriver\remote\webdriver.py", line 321, in execute
    self.error_handler.check_response(response)
  File "C:\python\lib\site-packages\selenium\webdriver\remote\errorhandler.py", line 242, in check_response
    raise exception_class(message, screen, stacktrace)
selenium.common.exceptions.ElementNotInteractableException: Message: element not interactable: element has zero size
  (Session info: chrome=84.0.4147.125)

【 2 と 3 の場合のエラー】

エラーの表示は無し。
ブラウザ上でも、何も起こらない。(ポップアップも表示されない)

補足情報(インポート、設定情報)

import os, pyodbc, datetime, shutil, time, chromedriver_binary
import pandas as pd
from selenium import webdriver

options = webdriver.ChromeOptions()
options.add_experimental_option('prefs', {
'download.default_directory': c_dir,
'download.prompt_for_download': False,
'download.directory_upgrade': True,
'safebrowsing.enabled': True
})

options.add_argument('--ignore-certificate-errors')
options.add_argument('--disable-extensions')
options.add_argument('--disable-print-preview')

driver = webdriver.Chrome(options=options)
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

0

元々のサイトがぼかされているので検証しようがないのですが、
ためしに目的の要素がクリック可能になるようにWebDriverWaitで誘導してみてはどうでしょうか。

from selenium import webdriver

webdriver.support.ui.WebDriverWait(driver ,20).until(
    webdriver.support.expected_conditions.element_to_be_clickable(
        webdriver.common.by.XPATH,
        '//*[@id="centerCol"]/div[1]/div[4]/div[2]/a[2]' #XPATH を指定
    )
).click()

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

2と3で何も表示されないのはaタグではなくimgタグをクリックしているからです。
aタグを叩くことで発火するようにサイトは作られているはずです。
リンクをクリックせずに写真をクリックしているだけなので何も起きません。

stdustさんの回答やsleepでうまく行かなかったら以下も試してみてください。
javascriptでxpathを叩いています。

driver.execute_script('document.evaluate(¥'//img[@id="to_cart"]/..¥', document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null ).snapshotItem(0).click();')


¥はバックスラッシュに置き換えてください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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