本文實例講述了Python使用scrapy采集數(shù)據(jù)時為每個請求隨機(jī)分配user-agent的方法。分享給大家供大家參考。具體分析如下:
通過這個方法可以每次請求更換不同的user-agent,防止網(wǎng)站根據(jù)user-agent屏蔽scrapy的蜘蛛
首先將下面的代碼添加到settings.py文件,替換默認(rèn)的user-agent處理模塊
代碼如下:DOWNLOADER_MIDDLEWARES = {
'scraper.random_user_agent.RandomUserAgentMiddleware': 400,
'scrapy.contrib.downloadermiddleware.useragent.UserAgentMiddleware': None,
}
自定義useragent處理模塊
代碼如下:from scraper.settings import USER_AGENT_LIST
import random
from scrapy import log
class RandomUserAgentMiddleware(object):
def process_request(self, request, spider):
ua = random.choice(USER_AGENT_LIST)
if ua:
request.headers.setdefault('User-Agent', ua)
#log.msg('>>>> UA %s'%request.headers)
希望本文所述對大家的Python程序設(shè)計有所幫助。
|
新聞熱點
疑難解答
圖片精選