2

我正在使用 geckodriver 在 Python ide 中运行 Selenium。

我试图打开的网站有一个 30 秒的计时器,在这 30 秒后出现一个按钮,我点击它。

我要问的是:我可以以某种方式忽略/跳过/加快等待时间吗?

现在我正在做的事情如下:

driver = webdriver.Firefox()
driver.get("SITE_URL")
sleep(30)
driver.find_element_by_id("proceed").click()

这是非常低效的,因为每次我运行代码进行一些测试时,我都需要等待。

在此先感谢,阿维。

更新: 我还没有找到克服障碍的方法,但在我这样做之前,我正试图专注于下一个可实现的进展:

<video class="jw-video jw-reset" disableremoteplayback="" webkit-playsinline="" playsinline="" preload="metadata" src="//SITE.SITE.SITE/SITE/480/213925.mp4?token=jbavPPLqNqkQT1SEUt4crg&amp;time=1525458550" style="object-fit: fill;"></video>

(审查网站的名称)

在每个页面中都有一个视频,所有视频都在“jw-video jw-reset”类下我无法按类查找元素,所以我使用了:

WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.CSS_SELECTOR, "video[class='jw-video jw-reset']")))

它可以工作,但我不知道如何选择元素的 src ...

4

1 回答 1

4

根据您的代码试用,您可以删除time.sleep(30)并诱导WebDriverWait元素可点击,如下所示:

from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
# lines of code
WebDriverWait(driver, 30).until(EC.element_to_be_clickable((By.ID, "proceed"))).click()

注意:根据您的用例为WebDriverWait实例配置最大时间限制。该expected_conditions方法将在元素可见启用element_to_be_clickable()后立即返回WebElement,以便您可以单击它。

于 2018-05-04T06:50:10.717 回答