【问题标题】:Selenium common exception Timeout exception Message: timeout ErrorSelenium 常见异常 Timeout exception Message: timeout Error
【发布时间】:2018-08-18 14:12:00
【问题描述】:

我一直在为 OkCupid 编写在线状态检查脚本。那么会发生什么,如果我正在监视的人登录 OkCupid,脚本将根据他们登录后显示的<div class="userinfo2015-basics-username-online-icon isOnline"></div> 检测它。它每分钟循环一次以查看是否有任何状态更改。在大多数情况下,它运行良好,可以持续 30-40 分钟,但随后会崩溃。 脚本的输出如下所示:

----------------------------------------------
[i] Status   |   Last Checked   |   Update   |
----------------------------------------------
[-] Offline      08-14 18:33:03     60 Sec   |
[+] Online       08-14 18:34:05     60 Sec   |
[+] Online       08-14 18:35:09     60 Sec   |
[+] Online       08-14 18:36:10     60 Sec   |
----------------------------------------------

这是循环:

try:
while 1:
        status = driver.find_elements_by_tag_name('div')[41].get_attribute('class') # Span Class for Online status
        driver.refresh()
        time_online = datetime.now().strftime('%m-%d %H:%M:%S')
        time.sleep(5)
        if status == str('userinfo2015-basics-username-online-icon isOnline'):
            print('[+]  Online'+7*' '+time_online+5*' '+str(update+5)+' Sec   |')
        elif status != str('userinfo2015-basics-username-online-icon isOnline'):
            print(bc.red+'[-] Offline'+6*' '+time_online+5*' '+str(update+5)+' Sec   |')
        time.sleep(update)
except KeyboardInterrupt:
        print('  Exiting\n'+46*'-')
driver.quit()

然后报错:

Traceback (most recent call last):
File "okCupid_online_status.py", line 38, in <module>
    status = driver.find_elements_by_tag_name('div')[41].get_attribute('class') # Span Class for Online status
  File "/usr/local/lib/python2.7/dist-packages/selenium/webdriver/remote/webdriver.py", line 539, in find_elements_by_tag_name
    return self.find_elements(by=By.TAG_NAME, value=name)
  File "/usr/local/lib/python2.7/dist-packages/selenium/webdriver/remote/webdriver.py", line 985, in find_elements
    'value': value})['value'] or []
  File "/usr/local/lib/python2.7/dist-packages/selenium/webdriver/remote/webdriver.py", line 314, in execute
    self.error_handler.check_response(response)
  File "/usr/local/lib/python2.7/dist-packages/selenium/webdriver/remote/errorhandler.py", line 242, in check_response
    raise exception_class(message, screen, stacktrace)
selenium.common.exceptions.TimeoutException: Message: timeout
  (Session info: chrome=67.0.3396.99)
  (Driver info: chromedriver=2.39.562737 (dba483cee6a5f15e2e2d73df16968ab10b38a2bf),platform=Linux 4.15.0-29-generic x86_64)

所以我更想知道如果发生这种情况,我是否可以引发异常并绕过错误,并让我的脚本继续循环?

【问题讨论】:

  • 你能捕捉到那个异常并让循环再次运行吗?有时你可以退出驱动程序并在一段时间后再次打开它

标签: python selenium


【解决方案1】:

很难确定,但根据我的经验,Selenium 中的 Timeout 异常经常发生在浏览器页面没有响应时。下次出现这种情况,我建议你检查一下是不是这样。

如果确实如此,那么因为您正在创建一个抓取工具(而不是测试自动化),您应该捕获异常并重试。如果您要编写测试自动化,我会说您应该报告有关它的错误,因为无响应的页面通常是页面的 JavaScript 代码中的错误。

【讨论】:

    猜你喜欢
    • 2014-06-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-01-16
    • 2012-07-11
    • 2019-06-14
    相关资源
    最近更新 更多