超簡單的scrapy實(shí)現(xiàn)ip動(dòng)態(tài)代理與更換ip的方法實(shí)現(xiàn)
簡單實(shí)現(xiàn)ip代理,為了不賣廣告,
請(qǐng)自行準(zhǔn)備一個(gè)ip代理的平臺(tái)
例如我用的這個(gè)平臺(tái),每次提取10個(gè)ip
從上面可以看到數(shù)據(jù)格式是文本,換行是\r\n,訪問鏈接之后大概就是長這樣的,scrapy里面的ip需要加上前綴http://
例如:http://117.95.41.21:34854
OK,那現(xiàn)在已經(jīng)準(zhǔn)備好了ip了,先給你們屢一下思路。
ip池和計(jì)數(shù)器放在setting文件
第一次請(qǐng)求的時(shí)候要填滿ip池,所以在爬蟲文件的start_requests函數(shù)下手
更換ip的地方是middlewares的下載器中間件類的process_request函數(shù),因?yàn)槊總€(gè)請(qǐng)求發(fā)起前都會(huì)經(jīng)過這個(gè)函數(shù)
首先是setting文件,其實(shí)就是加兩句代碼
count = {'count': 0} ipPool = []
還有就是開啟下載器中間件,注意是下面那個(gè)download的類,中間件的process_request函數(shù)的時(shí)候才能生效
下載器中間件的process_request函數(shù),進(jìn)行ip代理和固定次數(shù)更還ip代理池
# 記得導(dǎo)包 from 你的項(xiàng)目.settings import ipPool, count import random import requests def process_request(self, request, spider): # 隨機(jī)選中一個(gè)ip ip = random.choice(ipPool) print('當(dāng)前ip', ip, '-----', count['count']) # 更換request的ip----------這句是重點(diǎn) request.meta['proxy'] = ip # 如果循環(huán)大于某個(gè)值,就清理ip池,更換ip的內(nèi)容 if count['count'] > 50: print('-------------切換ip------------------') count['count'] = 0 ipPool.clear() ips = requests.get('你的ip獲取的地址') for ip in ips.text.split('\r\n'): ipPool.append('http://' + ip) # 每次訪問,計(jì)數(shù)器+1 count['count'] += 1 return None
最后就是爬蟲文件的start_requests函數(shù),就是第一次發(fā)請(qǐng)求前要先填滿ip池的ip
# 記得導(dǎo)包 from 你的項(xiàng)目.settings import ipPool import random import requests def start_requests(self): # 第一次請(qǐng)求發(fā)起前先填充一下ip池 ips = requests.get('你的ip獲取的地址') for ip in ips.text.split('\r\n'): ipPool.append('http://' + ip)
簡單的ip代理以及固定次數(shù)就更換ip池就完成了
到此這篇關(guān)于超簡單的scrapy實(shí)現(xiàn)ip動(dòng)態(tài)代理與更換ip的方法實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)scrapy ip動(dòng)態(tài)代理與更換ip內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決Python報(bào)錯(cuò):SyntaxError:?invalid?character?‘,‘?(U+FF0C)
Python中的 SyntaxError錯(cuò)誤是Python語言中常見的異常錯(cuò)誤類型之一,表示語法錯(cuò)誤,下面這篇文章主要給大家介紹了關(guān)于解決Python報(bào)錯(cuò):SyntaxError:?invalid?character?‘,‘?(U+FF0C)的相關(guān)資料,需要的朋友可以參考下2022-12-12pytorch-autograde-計(jì)算圖的特點(diǎn)說明
這篇文章主要介紹了pytorch-autograde-計(jì)算圖的特點(diǎn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05python獲取當(dāng)前目錄路徑和上級(jí)路徑的實(shí)例
下面小編就為大家分享一篇python獲取當(dāng)前目錄路徑和上級(jí)路徑的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-04-04pandas數(shù)據(jù)清洗,排序,索引設(shè)置,數(shù)據(jù)選取方法
下面小編就為大家分享一篇pandas數(shù)據(jù)清洗,排序,索引設(shè)置,數(shù)據(jù)選取方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05Python中循環(huán)后使用list.append()數(shù)據(jù)被覆蓋問題的解決
這篇文章主要給大家介紹了關(guān)于Python中循環(huán)后使用list.append()數(shù)據(jù)被覆蓋問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07django 前端頁面如何實(shí)現(xiàn)顯示前N條數(shù)據(jù)
這篇文章主要介紹了django 前端頁面如何實(shí)現(xiàn)顯示前N條數(shù)據(jù)。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03Django websocket原理及功能實(shí)現(xiàn)代碼
這篇文章主要介紹了Django websocket原理及功能實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11詳解Python 模擬實(shí)現(xiàn)生產(chǎn)者消費(fèi)者模式的實(shí)例
這篇文章主要介紹了詳解Python 模擬實(shí)現(xiàn)生產(chǎn)者消費(fèi)者模式的實(shí)例的相關(guān)資料,這里使用了線程知識(shí),隊(duì)列知識(shí)及循環(huán)的知識(shí),需要的朋友可以參考下2017-08-08