1. 程式人生 > >python使用http、https代理

python使用http、https代理

在國內利用Python從Internet上爬取資料時,有些網站或API介面被限速或遮蔽,這時使用代理可以加速爬取過程,減少請求失敗,Python程式使用代理的方法主要有以下幾種:

(1)如果是在程式碼中使用一些網路庫或爬蟲框架進行資料爬取,一般這種框架都會支援設定代理,例如:

import urllib.request as urlreq
# 設定https代理
ph = urlreq.ProxyHandler({'https': 'https://127.0.0.1:1080'})
oper = urlreq.build_opener(ph)
# 將代理安裝到全域性環境,這樣所有請求都會自動使用代理
urlreq.install_opener(oper)
res = oper.open("https://www.google.com")
print(res.read())
import requests as req
print(req.get("https://www.google.com", proxies={'https': 'https://127.0.0.1:1080'}).content)
(2)如果使用的庫沒有提供設定代理的介面,但是底層使用了urllib、requests等庫,可以嘗試設定HTTP_PROXY 和HTTPS_PROXY環境變數,常用的網路庫會自動識別這些環境變數,使用變數設定的代理髮起請求,設定如下:

import os
os.environ['http_proxy'] = 'http://127.0.0.1:1080'
os.environ['https_proxy'] = 'https://127.0.0.1:1080'
(3)如果上述兩種方法都沒有用,那麼還可以使用一些可以監聽、攔截和修改網路包的工具和庫如(Fiddler、mitmproxy)來攔截http請求包並修改地址,達到使用代理的效果。
---------------------
作者:wanghong5211
來源:CSDN
原文:https://blog.csdn.net/wanghong5211/article/details/70596425
版權宣告:本文為博主原創文章,轉載請附上博文連結!