Поэтому я пытаюсь работать с python 2.7, чтобы делать разные вещи, требующие извлечения данных из Интернета. Я не был очень успешным, и я ищу помощи, чтобы диагностировать, что я делаю неправильно.
Во-первых, мне удалось заставить pip работать, определив прокси-сервер таким образом, pip install --proxy=http://username:[email protected]:8080 numpy
. Следовательно, Python должен быть в состоянии пройти через это!
Однако, когда дело дошло до написания сценария .py, который мог бы сделать то же самое, у меня не было успеха. Сначала я попытался использовать следующий код с urllib2:
import urllib2
uri = "http://www.python.org"
http_proxy_server = "someproxyserver.com"
http_proxy_port = "8080"
http_proxy_realm = http_proxy_server
http_proxy_user = "username"
http_proxy_passwd = "password"
# Next line = "http://username:[email protected]:8080"
http_proxy_full_auth_string = "http://%s:%s@%s:%s" % (http_proxy_user,
http_proxy_passwd,
http_proxy_server,
http_proxy_port)
def open_url_no_proxy():
urllib2.urlopen(uri)
print "Apparent success without proxy server!"
def open_url_installed_opener():
proxy_handler = urllib2.ProxyHandler({"http": http_proxy_full_auth_string})
opener = urllib2.build_opener(proxy_handler)
urllib2.install_opener(opener)
urllib2.urlopen(uri)
print "Apparent success through proxy server!"
if __name__ == "__main__":
open_url_no_proxy()
open_url_installed_opener()
Однако я просто получаю эту ошибку:
URLError: <urlopen error [Errno 10060] A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond>
Затем я попробовал urllib3, так как это модуль, используемый pip для обработки прокси:
from urllib3 import ProxyManager, make_headers
# Establish the Authentication Settings
default_headers = make_headers(basic_auth='username:password')
http = ProxyManager("https://www.proxy.com:8080/", headers=default_headers)
# Now you can use `http` as you would a normal PoolManager
r = http.request('GET', 'https://www.python.org/')
# Check data is from destination
print(r.data)
Я получил эту ошибку:
raise MaxRetryError(_pool, url, error or ResponseError(cause)) MaxRetryError: HTTPSConnectionPool(host='www.python.org', port=443): Max retries exceeded with url: / (Caused by ProxyError('Cannot connect to proxy.', error('Tunnel connection failed: 407 Proxy Authorization Required',)))
Я был бы очень признателен за любую помощь в диагностике этой проблемы.