python中使用requests语句报错的原因主要有以下几种情况:
1 连接超时
服务器在指定时间内没有应答,抛出 requests.exceptions.ConnectTimeout
requests.get('http://github.com', timeout=0.001)
# 抛出错误
requests.exceptions.ConnectTimeout: HTTPConnectionPool(host='github.com', port=80): Max retries exceeded with url: / (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x7f1b16da75f8>, 'Connection to github.com timed out. (connect timeout=0.001)'))
2. 连接、读取超时
如果分别指定连接超时和读取超时,则服务器在指定时间内没有响应并抛出 requests.exceptions.ConnectTimeout
- timeout=([连接超时时间], [读取超时时间])
- 连接:客户端连接服务器并并发送http请求服务器
- 读取:客户端在服务器发送第一个字节之前等待的时间
requests.get('http://github.com', timeout=(6.05, 0.01))
# 抛出错误
requests.exceptions.ReadTimeout: HTTPConnectionPool(host='github.com', port=80): Read timed out.
(read timeout=0.01)
3. 未知的服务器
抛出 requests.exceptions.ConnectionError
requests.get('http://github.comasf', timeout=(6.05, 27.05))
# 抛出错误
requests.exceptions.ConnectionError: HTTPConnectionPool(host='github.comasf', port=80): Max retries exceeded
with url: / (Caused by NewConnectionError('<urllib3.connection.HTTPConnection object at 0x7f75826665f8>:
Failed to establish a new connection: [Errno -2] Name or service not known',))
4. 代理连接不上
代理服务器拒绝建立连接,端口拒绝连接或未打开,抛出 requests.exceptions.ProxyError
requests.get('http://github.com', timeout=(6.05, 27.05), proxies={"http": "192.168.10.1:800"})
# 抛出错误
requests.exceptions.ProxyError: HTTPConnectionPool(host='192.168.10.1', port=800): Max retries exceeded with
url: http://github.com/ (Caused by ProxyError('Cannot connect to proxy.', NewConnectionError('<urllib3.
connection.HTTPConnection object at 0x7fce3438c6d8>: Failed to establish a new connection: [Errno 111]
Connection refused',)))
5. 连接代理超时
代理服务器没有响应 requests.exceptions.ConnectTimeout
requests.get('http://github.com', timeout=(6.05, 27.05), proxies={"http": "10.200.123.123:800"})
# 抛出错误
requests.exceptions.ConnectTimeout: HTTPConnectionPool(host='10.200.123.123', port=800): Max retries exceeded
with url: http://github.com/ (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at
0x7fa8896cc6d8>, 'Connection to 10.200.123.123 timed out. (connect timeout=6.05)'))
6. 代理读取超时
表示与proxy建立连接成功,proxy也向目标站点发送请求,但是proxy读取目标站点资源超时
即使代理访问非常快,如果代理服务器访问的目标站点超时,这个锅仍然是代理服务器的背。
假设代理可用,timeout是连接和读取过程到代理服务器的超时时间,不管代理服务器是否成功连接和读取
requests.get('http://github.com', timeout=(2, 0.01), proxies={"http": "192.168.10.1:800"})
# 抛出错误
requests.exceptions.ReadTimeout: HTTPConnectionPool(host='192.168.10.1:800', port=1080): Read timed out. (read
timeout=0.5)
7. 网络环境异常
可能是断网导致,抛出 requests.exceptions.ConnectionError
requests.get('http://github.com', timeout=(6.05, 27.05))
# 抛出错误
requests.exceptions.ConnectionError: HTTPConnectionPool(host='github.com', port=80): Max retries exceeded with
url: /
(Caused by NewConnectionError('<urllib3.connection.HTTPConnection object at 0x7fc8c17675f8>: Failed to
establish a new
connection: [Errno -3] Temporary failure in name resolution',))
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python如何装饰带参数的装饰器01/05
- ♥ Python 使用生成器实现协程12/17
- ♥ 如何从python中的列表中删除重复项12/31
- ♥ 如何在python中写入txt文件路径11/09
- ♥ Python 中的 search() 和 match() 有什么区别11/30
- ♥ python程序如何实现接口封装、请求、调用?09/17
内容反馈