MaxRetryError:HTTPConnectionPool:超过最大重试次数(由ProtocolError(“连接中止。”,错误(111,“连接被拒绝”)引起)) - python

我有一个问题:我想测试“选择”和“输入”。是否可以像下面的代码一样编写它:
原始代码:

     12 class Sinaselecttest(unittest.TestCase):
     13 
     14     def setUp(self):
     15         binary = FirefoxBinary('/usr/local/firefox/firefox')
     16         self.driver = webdriver.Firefox(firefox_binary=binary)
     17 
     18     def test_select_in_sina(self):
     19         driver = self.driver
     20         driver.get("https://www.sina.com.cn/")
     21         try:
     22             WebDriverWait(driver,30).until(
     23                 ec.visibility_of_element_located((By.XPATH,"/html/body/div[9]/div/div[1]/form/div[3]/input"))
     24             )
     25         finally:
     26             driver.quit()
     # #测试select功能
     27         select=Select(driver.find_element_by_xpath("//*[@id='slt_01']")).select_by_value("微博")
     28         element=driver.find_element_by_xpath("/html/body/div[9]/div/div[1]/form/div[3]/input")
     29         element.send_keys("杨幂")
     30         driver.find_element_by_xpath("/html/body/div[9]/div/div[1]/form/input").click()
     31         driver.implicitly_wait(5)
     32 
     33         
     34    

我想测试Selenium的“选择”功能。所以我选择sina网站选择一个选项并在textarea中输入文本。然后搜索它。但是当我运行此测试时,它有错误:

 Traceback (most recent call last):
      File "test_sina_select.py", line 32, in tearDown
        self.driver.close()
      File "/usr/lib/python2.7/site-packages/selenium/webdriver/remote/webdriver.py", line 688, in close
        self.execute(Command.CLOSE)
      File "/usr/lib/python2.7/site-packages/selenium/webdriver/remote/webdriver.py", line 319, in execute
        response = self.command_executor.execute(driver_command, params)
      File "/usr/lib/python2.7/site-packages/selenium/webdriver/remote/remote_connection.py", line 376, in execute
        return self._request(command_info[0], url, body=data)
      File "/usr/lib/python2.7/site-packages/selenium/webdriver/remote/remote_connection.py", line 399, in _request
        resp = self._conn.request(method, url, body=body, headers=headers)
      File "/usr/lib/python2.7/site-packages/urllib3/request.py", line 68, in request
        **urlopen_kw)
      File "/usr/lib/python2.7/site-packages/urllib3/request.py", line 81, in request_encode_url
        return self.urlopen(method, url, **urlopen_kw)
      File "/usr/lib/python2.7/site-packages/urllib3/poolmanager.py", line 247, in urlopen
        response = conn.urlopen(method, u.request_uri, **kw)
      File "/usr/lib/python2.7/site-packages/urllib3/connectionpool.py", line 617, in urlopen
        release_conn=release_conn, **response_kw)
      File "/usr/lib/python2.7/site-packages/urllib3/connectionpool.py", line 617, in urlopen
        release_conn=release_conn, **response_kw)
      File "/usr/lib/python2.7/site-packages/urllib3/connectionpool.py", line 617, in urlopen
        release_conn=release_conn, **response_kw)
      File "/usr/lib/python2.7/site-packages/urllib3/connectionpool.py", line 597, in urlopen
        _stacktrace=sys.exc_info()[2])
      File "/usr/lib/python2.7/site-packages/urllib3/util/retry.py", line 271, in increment
        raise MaxRetryError(_pool, url, error or ResponseError(cause))
    MaxRetryError: HTTPConnectionPool(host='127.0.0.1', port=51379): Max retries exceeded with url: /session/2e64d2a1-3c7f-4221-96fe-9d0b1c102195/window (Caused by ProtocolError('Connection aborted.', error(111, 'Connection refused')))

    ----------------------------------------------------------------------
    Ran 1 test in 72.106s

谁能告诉我为什么?谢谢

参考方案

此错误消息...

MaxRetryError: HTTPConnectionPool(host='127.0.0.1', port=51379): Max retries exceeded with url: /session/2e64d2a1-3c7f-4221-96fe-9d0b1c102195/window (Caused by ProtocolError('Connection aborted.', error(111, 'Connection refused')))

...表示get()方法无法引发MaxRetryError。

有两件事:

首先,根据讨论max-retries-exceeded exceptions are confusing,回溯在某种程度上具有误导性。请求包装异常是为了方便用户。原始异常是显示的消息的一部分。
请求永不重试(它为urllib3的retries=0设置了HTTPConnectionPool),因此如果没有MaxRetryError和HTTPConnectionPool关键字,该错误将更为规范。因此理想的回溯应该是:

ConnectionError(<class 'socket.error'>: [Errno 1111] Connection refused)

但是@ sigmavirus24在他的comment中再次提到...包装这些异常会产生出色的API,但会带来不良的调试体验...
向前推进的计划是尽可能向下遍历最低级别的异常,并使用它。
最后,通过改写一些与实际连接拒绝错误无关的异常来解决此问题。

根据Selenium 3.14.1的发行说明:

* Fix ability to set timeout for urllib3 (#6286)

合并为:repair urllib3 can't set timeout!

结论

升级到Selenium 3.14.1之后,您将可以设置超时并查看规范的回溯,并且可以采取必要的措施。

参考资料

几个相关的事件引用:

Adding max_retries as an argument
Removed the bundled charade and urllib3.
Third party libraries committed verbatim

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

python-docx应该在空单元格已满时返回空单元格 - python

我试图遍历文档中的所有表并从中提取文本。作为中间步骤,我只是尝试将文本打印到控制台。我在类似的帖子中已经看过scanny提供的其他代码,但是由于某种原因,它并没有提供我正在解析的文档的预期输出可以在https://www.ontario.ca/laws/regulation/140300中找到该文档from docx import Document from…

Python:集群作业管理 - python

我在具有两个阶段的计算群集(Slurm)上运行python脚本,它们是顺序的。我编写了两个python脚本,一个用于阶段1,另一个用于阶段2。每天早上,我检查所有第1阶段的工作是否都以视觉方式完成。只有这样,我才开始第二阶段。通过在单个python脚本中组合所有阶段和作业管理,是否有一种更优雅/自动化的方法?我如何知道工作是否完成?工作流程类似于以下内容:w…

Python:传递记录器是个好主意吗? - python

我的Web服务器的API日志如下:started started succeeded failed 那是同时收到的两个请求。很难说哪一个成功或失败。为了彼此分离请求,我为每个请求创建了一个随机数,并将其用作记录器的名称logger = logging.getLogger(random_number) 日志变成[111] started [222] start…