3
Traceback (most recent call last):
  File "Inventorytest.py", line 88, in <module>
    j.go_to_application()
  File "Inventorytest.py", line 65, in go_to_application
    EC.element_to_be_clickable((By.ID, 'FavoriteApp_ITEM'))
  File "/home/naroladev/Mercury_Back-End/mercuryenv/lib/python3.6/site-packages/selenium/webdriver/support/wait.py", line 80, in until
    raise TimeoutException(message, screen, stacktrace)
selenium.common.exceptions.TimeoutException: Message: 

我遇到了 EC2 服务器实例的上述异常。我的脚本在本地系统上使用任何版本的 firefox 和 geckodriver 的 Ubuntu 和 Mac 操作系统都可以正常工作。但是 EC2 ubuntu 18.04.01 版本出现上述错误,在此我也尝试过升级和降级 firefox 和 geckodriver 版本,但仍然无法正常工作。任何人都可以帮助我提出建议和解决方案。

4

1 回答 1

1

此错误消息...

Traceback (most recent call last):
  File "Inventorytest.py", line 88, in <module>
    j.go_to_application()
  File "Inventorytest.py", line 65, in go_to_application
    EC.element_to_be_clickable((By.ID, 'FavoriteApp_ITEM'))
  File "/home/naroladev/Mercury_Back-End/mercuryenv/lib/python3.6/site-packages/selenium/webdriver/support/wait.py", line 80, in until
    raise TimeoutException(message, screen, stacktrace)
selenium.common.exceptions.TimeoutException: Message: 

...意味着WebDriver变体无法在构建WebDriverWait的时间范围内找到所需的WebElement


WebDriverWait

WebDriverWait构造函数将WebDriver实例作为参数并以秒为单位超时。

因此,无论使用任何一个expected_conditionsWebDriverWait失败都会导致TimeoutException


这个用例

在此用例中,该行:

EC.element_to_be_clickable((By.ID, 'FavoriteApp_ITEM'))

无法在所需的时间范围内识别所需的元素,因此您面临TimeoutException

但是,从TimeoutException中很难挖掘出失败的实际结果。


解决方案

作为了解失败确切原因的解决方案,您需要删除WebDriverWait并将代码行替换为:

  • find_element_by_class_name(name)
  • find_element_by_css_selector(css_selector)
  • find_element_by_id(id)
  • find_element_by_link_text(link_text)
  • find_element_by_name(name)
  • find_element_by_partial_link_text(partial_link_text)
  • find_element_by_tag_name(tag_name)
  • find_element_by_xpath(xpath)

time.sleep(secs)如果需要,您可以在调试时减慢搜索诱导等待的速度。


参考

您可以在以下位置找到一些相关的讨论:

于 2020-07-21T17:42:45.080 回答