使用Python更換外網(wǎng)IP的方法
在進(jìn)行數(shù)據(jù)抓取時(shí),經(jīng)常會(huì)遇到IP被限制的情況,常見(jiàn)的解決方案是搭建代理IP池,或購(gòu)買IP代理的服務(wù)。除此之外,還有一個(gè)另外的方法就是使用家里的寬帶網(wǎng)絡(luò)進(jìn)行抓取。由于家里的寬帶每次斷開(kāi)重新連接時(shí)都會(huì)分配一個(gè)新的IP,所以在我們抓取數(shù)據(jù)的時(shí)候,判斷當(dāng)IP被禁掉時(shí),立即在路由器中進(jìn)行斷開(kāi)重新連接操作??紤]到人工操作比較繁瑣,另外也不可能一直盯著執(zhí)行的程序,就考慮使用Python自動(dòng)多路由器進(jìn)行設(shè)置。
以下代碼為針對(duì)家里的TP-Link進(jìn)行的設(shè)置,其他路由器的設(shè)置原理也應(yīng)該一樣。
import base64, requests, time, re
base_url = 'http://192.168.1.1'
user = 'admin'
pwd = 'password'
headers = {
'Accept': '*/*',
'User-Agent': 'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET4.0C; .NET4.0E)',
'Referer': base_url + '/userRpm/StatusRpm.htm',
'Cookie': 'Authorization=Basic ' + base64.b64encode((user + ':' + pwd).encode(encoding='utf-8')).decode(
encoding='utf-8')
}
def get_ip():
url = "http://2018.ip138.com/ic.asp"
r = requests.get(url)
txt = r.text
ip = txt[txt.find("[") + 1: txt.find("]")]
return ip
def get_ip_status():
url = base_url + "/userRpm/StatusRpm.htm"
r = requests.get(url=url, headers=headers)
pattern = re.compile('(\d+\.\d+\.\d+\.\d+)')
ip = re.findall(pattern,r.text)
return ip[3]
def change_ip():
url = base_url + '/userRpm/StatusRpm.htm?Disconnect=%B6%CF%20%CF%DF&wan=1'
requests.get(url=url, headers=headers)
while True:
time.sleep(5)
new_ip = get_ip_status()
if new_ip != '0.0.0.0':
break
if __name__ == "__main__":
change_ip()
以上代碼已經(jīng)經(jīng)過(guò)測(cè)試,能夠正常使用。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python 執(zhí)行字符串表達(dá)式函數(shù)(eval exec execfile)
今天在網(wǎng)上搜尋一些應(yīng)用的例子時(shí),發(fā)現(xiàn)有人用TK僅僅幾行代碼就寫了個(gè)簡(jiǎn)易的計(jì)算器,驚為天人。回憶起剛學(xué)軟件技術(shù)基礎(chǔ)時(shí)編寫簡(jiǎn)易計(jì)算器的艱辛,頓時(shí)淚流滿面2014-08-08
Python中的google authenticator認(rèn)證過(guò)程
文章介紹了使用Python 3.7生成Google Authenticator所需密鑰的步驟,包括使用pyotp模塊生成密鑰、生成二維碼圖片以及通過(guò)客戶端掃描二維碼進(jìn)行二次認(rèn)證的實(shí)現(xiàn)原理2024-11-11
關(guān)于pyinstaller?打包多個(gè)py文件的問(wèn)題
這篇文章主要介紹了pyinstaller?打包多個(gè)py文件及遇到的問(wèn)題,本文通過(guò)實(shí)例代碼給大家詳細(xì)介紹,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-10-10
Python數(shù)值求解微分方程方法(歐拉法,隱式歐拉)
這篇文章主要介紹了Python數(shù)值求解微分方程方法(歐拉法,隱式歐拉),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
Python爬蟲(chóng)實(shí)現(xiàn)網(wǎng)頁(yè)信息抓取功能示例【URL與正則模塊】
這篇文章主要介紹了Python爬蟲(chóng)實(shí)現(xiàn)網(wǎng)頁(yè)信息抓取功能,涉及Python使用URL與正則模塊針對(duì)網(wǎng)頁(yè)信息的讀取與匹配相關(guān)操作技巧,需要的朋友可以參考下2017-05-05
使用Python獲取網(wǎng)段IP個(gè)數(shù)以及地址清單的方法
今天小編就為大家分享一篇使用Python獲取網(wǎng)段IP個(gè)數(shù)以及地址清單的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
Python MySQL如何通過(guò)Binlog獲取變更記錄恢復(fù)數(shù)據(jù)
本文介紹了如何使用Python和pymysqlreplication庫(kù)通過(guò)MySQL的二進(jìn)制日志(Binlog)獲取數(shù)據(jù)庫(kù)的變更記錄,并展示了一個(gè)簡(jiǎn)單的Python腳本,該腳本讀取Binlog事件并打印出插入、更新和刪除操作的SQL語(yǔ)句,此外,還提到可以使用pandas將結(jié)果輸出到Excel表格中進(jìn)行數(shù)據(jù)分析處理2025-01-01
Django如何配置mysql數(shù)據(jù)庫(kù)
這篇文章主要為大家詳細(xì)介紹了Django配置mysql數(shù)據(jù)庫(kù)的詳細(xì)步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
Python列表pop()函數(shù)使用實(shí)例詳解
這篇文章主要介紹了Python列表pop()函數(shù)使用實(shí)例詳解,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07

