当前位置: 首页 > wzjs >正文

建网站流程四年级新闻摘抄大全

建网站流程,四年级新闻摘抄大全,福州建设网站效果,艺术字logo设计在线生成1.中间件 根据scrapy运行流程中所在位置不同分为 下载中间件爬虫中间件自定义中间件 中间件的作用 预处理request和response对象 如果响应状态码不是200则请求重试(重新构造Request对象返回给引擎)可以对header以及cookie进行更换和处理使用代理ip等…

1.中间件

根据scrapy运行流程中所在位置不同分为

  1. 下载中间件
  2. 爬虫中间件
  3. 自定义中间件

中间件的作用

预处理requestresponse对象

  1. 如果响应状态码不是200则请求重试(重新构造Request对象返回给引擎)
  2. 可以对header以及cookie进行更换和处理
  3. 使用代理ip

但在Scrapy默认的情况下,两种中间件都在middlewares.py一个文件中。爬虫中间件使用方法和下载中间件相同,且功能重复,常使用下载中间件。

下载中间件的内部方法

Downloader Middlewares默认的方法:

  • process_request(self, request, spider)
    1. 当每个request通过下载中间件时,该方法被调用
    2. 返回None值:没有return也是返回None,该request对象传递给下载器,或通过引擎传递给其他权重低的process_request方法
    3. 返回Response对象:不再请求,把response返回给引擎
    4. 返回Request对象:把request对象通过引擎交给调度器,此时将不通过其他权重低的process_request方法

  • process_response(self, request, response, spider)
    1. 当下载器完成http请求,传递响应给引擎的时候调用
    2. 返回Resposne对象:通过引擎交给爬虫处理或交给权重更低的其他下载中间件的process_response方法
    3. 返回Request对象:通过引擎交给调度器继续请求,此时将不通过其他权重低的process_request方法

注意:需要在settings.py文件中开启中间件,权重越小越优先执行。

原始中间件一共封装五个方法,一般以下载中间件为例

def from_crawler(cls, crawler):d

作用:发送信号

def process_request(self, request, spider):

作用:处理请求对象

def process_response(self, request, response, spider):

作用:处理响应对象

def process_exception(self, request, exception, spider):

作用:捕获异常

def spider_opened(self, spider):

作用:日志记录,爬虫开始前的准备

2.设置动态UA

        scrapy自动中间件基本不用,也可以用。咱们自定义设置UA中间件,虽然说可以设置在一个py文件里,但把中间件放在一个文件夹里,方便改动。

一般中间件设在爬虫开始前,也就是def process_request(self, request, spider):里面

from scrapy import signals# useful for handling different item types with a single interface
from itemadapter import is_item, ItemAdapterimport randomclass UserAgentMiddleware:USER_AGENTS_LIST = ["Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET CLR 2.0.50727; Media Center PC 6.0)","Mozilla/5.0 (compatible; MSIE 8.0; Windows NT 6.0; Trident/4.0; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET CLR 1.0.3705; .NET CLR 1.1.4322)","Mozilla/4.0 (compatible; MSIE 7.0b; Windows NT 5.2; .NET CLR 1.1.4322; .NET CLR 2.0.50727; InfoPath.2; .NET CLR 3.0.04506.30)","Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN) AppleWebKit/523.15 (KHTML, like Gecko, Safari/419.3) Arora/0.3 (Change: 287 c9dfb30)","Mozilla/5.0 (X11; U; Linux; en-US) AppleWebKit/527+ (KHTML, like Gecko, Safari/419.3) Arora/0.6","Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.2pre) Gecko/20070215 K-Ninja/2.1.1","Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9) Gecko/20080705 Firefox/3.0 Kapiko/3.0","Mozilla/5.0 (X11; Linux i686; U;) Gecko/20070322 Kazehakase/0.4.5"]def process_request(self, request, spider):print("------下载中间件----")# 随机选择UAuser_agent = random.choice(self.USER_AGENTS_LIST)request.headers['User-Agent'] = user_agent# 不写return"""如果返回None, 表示当前的response提交下一个权重低的process_request。如果传递到最后一个process_request,则传递给下载器进行下载。"""

动态UA封装好了,下一步往中间件里开启请求中间件,注意路径,注意是下载器中间件

DOWNLOADER_MIDDLEWARES = {# 'myspider.middlewares.MyspiderDownloaderMiddleware': 543,'myspider.middlewares.UA_middlewares.UserAgentMiddleware': 100,
}

以百度为例,测试:

测试如下:

3.设置ip代理池

以快代理文档为例,照着官方文档

往项目根目录下添加文件

#!/usr/bin/env python
# -- coding: utf-8 --
import time
import threadingimport requests
from scrapy import signals# 提取代理IP的api
api_url = 'https://dps.kdlapi.com/api/getdps/?secret_id=ognun8vlg7vrdu7v79dh&signature=m3omx2nq0e7ve3jij071jw2xbkehs6th&num=10&format=json&sep=1'
foo = Trueclass Proxy:def __init__(self, ):self._proxy_list = requests.get(api_url).json().get('data').get('proxy_list')@propertydef proxy_list(self):return self._proxy_list@proxy_list.setterdef proxy_list(self, list):self._proxy_list = listpro = Proxy()
print(pro.proxy_list)class MyExtend:def __init__(self, crawler):self.crawler = crawler# 将自定义方法绑定到scrapy信号上,使程序与spider引擎同步启动与关闭# scrapy信号文档: https://www.osgeo.cn/scrapy/topics/signals.html# scrapy自定义拓展文档: https://www.osgeo.cn/scrapy/topics/extensions.htmlcrawler.signals.connect(self.start, signals.engine_started)crawler.signals.connect(self.close, signals.spider_closed)@classmethoddef from_crawler(cls, crawler):return cls(crawler)def start(self):t = threading.Thread(target=self.extract_proxy)t.start()def extract_proxy(self):while foo:pro.proxy_list = requests.get(api_url).json().get('data').get('proxy_list')#设置每15秒提取一次iptime.sleep(15)def close(self):global foofoo = False

 然后在设置一个中间件

 设置好自己的账号和密码

#!/usr/bin/env python 
# -- coding: utf-8 -- """
middlewares.py 中新增 ProxyDownloaderMiddleware 即代理中间件
请注意替换代码中的部分信息:username:用户名,password:密码
"""from scrapy import signals
from myspider.myextend import pro
import randomclass ProxyDownloaderMiddleware:def process_request(self, request, spider):proxy = random.choice(pro.proxy_list)# 用户名密码认证(私密代理/独享代理)username = ""password = ""request.meta['proxy'] = "http://%(user)s:%(pwd)s@%(proxy)s/" % {"user": username, "pwd": password, "proxy": proxy}# 白名单认证(私密代理/独享代理)# request.meta['proxy'] = "http://%(proxy)s/" % {"proxy": proxy}return None

最后在setting设置

既可以成功设置ip代理池,携带代理ip在请求回调参数里的meta['proxy']里面。

原来是通过中间件设置快代理api,然后可以设置一次性获得几个ip,然后随机携带代理ip,并且还可以几秒后重新获取ip。

还是按以下测试:

 结果如下:

 但有一个问题是,如果并不是每一个爬虫需要代理ip。直接设置在中间件,相当于每次运行都要提取ip,造成ip浪费。

4.爬虫自设置ip代理。

第一步在setting.py注释掉ip中间件

第二步 custom_setting自定义设置ip中间件

custom_settings = {}

 在爬虫添加这个,即表示添加代理

    custom_settings = {'DOWNLOADER_MIDDLEWARES': {'myspider.middlewares.ProxyDownloaderMiddleware.ProxyDownloaderMiddleware': 200,},}

 

效果如下: 

但是注意,一旦爬虫自定义中间件的话,以爬虫自定义的中间件为主。 

第四阶段,结束。

http://www.dtcms.com/wzjs/74966.html

相关文章:

  • 工业设计网站设计城市分站seo
  • 天津住房和城乡建设部网站百度收录规则
  • 自己做公众号引流到其他电影网站可以百度小说免费阅读
  • 杯子电子商务网站的建设百度云搜索
  • 为什么要给大夫做网站seo搜索
  • wordpress灯箱代码seo优化关键词
  • 学做网站要多久seo诊断网站
  • 网站建设唯地带谷歌官网
  • 现在网站如何做优化竞价推广出价多少合适
  • 武汉有那些做网站设计的公司环球网疫情最新动态
  • 渭南微网站建设网站关键词怎么优化排名
  • 网页制作实践 做网站百度指数官方网站
  • 淘宝入驻网站建设网络营销策划书模板
  • 杭州软件开发公司百度点击优化
  • 网站建设公司首选收录好的网站
  • 个人网站设计与开发网站快速排名
  • 英文网站怎么做seo排名优化价格
  • 何为网络营销?滕州网站建设优化
  • 体育网站建设需求静态网页设计与制作
  • php免费网站模板推广公司主要做什么
  • 网站开发设计jw100百度普通版下载
  • wordpress网站备案建设公司网站大概需要多少钱?
  • 大型网站建设一般多少钱网络运营
  • 网站开发框架是什么谷歌浏览器官网下载安装
  • 自助建设网站软件网站建立
  • 网站搭建配置企业营销策略有哪些
  • 网站弹出百度模拟点击
  • 安徽网站建设推荐-晨飞网络短视频广告投放平台
  • 网站建设合作品牌乌鲁木齐seo
  • 重庆市公共资源交易中心网站关键词搜索排名优化