Scrapy持久化存储

1. 基于终端指令的持久化存储

  • 保证爬虫文件的parse方法中有可迭代类型对象(通常为列表or字典)的返回,该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化操作。
 # 终端指令: 只可以将parse方法的返回值进行本地文件的持久化存储
 # 执行输出指定格式进行存储:将爬取到的数据写入不同格式的文件中进行存储
     scrapy crawl 爬虫名称 -o xxx.json
     scrapy crawl 爬虫名称 -o xxx.xml
     scrapy crawl 爬虫名称 -o xxx.csv

2. 基于管道的持久化存储

scrapy框架中已经为我们专门集成好了高效、便捷的持久化操作功能,我们直接使用即可。要想使用scrapy的持久化操作功能,我们首先来认识如下两个文件:

 items.py  # 数据结构模板文件。定义数据属性。
 pipelines.py  # 管道文件。接收数据(items),进行持久化操作。
 ?
 #持久化流程:
     1.爬虫文件爬取到数据后,需要将数据封装到items对象中。
     2.使用yield关键字将items对象提交给pipelines管道进行持久化操作。
     3.在管道文件中的process_item方法中接收爬虫文件提交过来的item对象,然后编写持久化存储的代码将item对象中存储的数据进行持久化存储
     4.settings.py配置文件中开启管道

将糗事百科首页中的段子和作者数据爬取下来,然后进行持久化存储

- 爬虫文件:qiubaiDemo.py ?

 import scrapy
 from secondblood.items import SecondbloodItem
 ?
 class QiubaidemoSpider(scrapy.Spider):
     name = ‘qiubaiDemo‘
     allowed_domains = [‘www.qiushibaike.com‘]
     start_urls = [‘http://www.qiushibaike.com/‘]
 ?
     def parse(self, response):
         odiv = response.xpath(‘//div[@id="content-left"]/div‘)
         for div in odiv:
             # xpath函数返回的为列表,列表中存放的数据为Selector类型的数据。我们解析到的内容被封装在了Selector对象中,需要调用extract()函数将解析的内容从Selecor中取出。
             # 能保证列表中只有一个 .extract_first()
             author = div.xpath(‘.//div[@class="author clearfix"]//h2/text()‘).extract_first()
             author = author.strip(‘\n‘)#过滤空行
             content = div.xpath(‘.//div[@class="content"]/span/text()‘).extract_first()
             content = content.strip(‘\n‘)#过滤空行
 ?
             #将解析到的数据封装至items对象中
             item = SecondbloodItem()
             item[‘author‘] = author
             item[‘content‘] = content
 ?
             yield item#提交item到管道文件(pipelines.py)

- 管道文件:pipelines.py

 # Define your item pipelines here
 #
 # Don‘t forget to add your pipeline to the ITEM_PIPELINES setting
 # See: https://doc.scrapy.org/en/latest/topics/item-pipeline.html
 ?
 ?
 class SecondbloodPipeline(object):
     #构造方法
     def __init__(self):
         self.fp = None  #定义一个文件描述符属性
   #下列都是在重写父类的方法:
     #开始爬虫时,执行一次
     def open_spider(self,spider):
         print(‘爬虫开始‘)
         self.fp = open(‘./data.txt‘, ‘w‘)
 ?
    #因为该方法会被执行调用多次,所以文件的开启和关闭操作写在了另外两个只会各自执行一次的方法中。
     def process_item(self, item, spider):
         #将爬虫程序提交的item进行持久化存储
         self.fp.write(item[‘author‘] + ‘:‘ + item[‘content‘] + ‘\n‘)
         return item
 ?
     #结束爬虫时,执行一次
     def close_spider(self,spider):
         self.fp.close()
         print(‘爬虫结束‘)

- 配置文件:settings.py

 #开启管道
 ITEM_PIPELINES = {
     ‘secondblood.pipelines.SecondbloodPipeline‘: 300, #300表示为优先级,值越小优先级越高
 }

2.1 基于mysql的管道存储

在管道文件里将item对象中的数据值存储到了磁盘中,如果将item数据写入mysql数据库的话,只需要将上述案例中的管道文件修改成如下形式:

- pipelines.py文件

# Define your item pipelines here
 #
 # Don‘t forget to add your pipeline to the ITEM_PIPELINES setting
 # See: https://doc.scrapy.org/en/latest/topics/item-pipeline.html
 ?
 #导入数据库的类
 import pymysql
 class QiubaiproPipelineByMysql(object):
 ?
     conn = None  #mysql的连接对象声明
     cursor = None#mysql游标对象声明
     def open_spider(self,spider):
         print(‘开始爬虫‘)
         #链接数据库
         self.conn = pymysql.Connect(host=‘127.0.0.1‘,port=3306,user=‘root‘,password=‘123456‘,db=‘qiubai‘)
     #编写向数据库中存储数据的相关代码
     def process_item(self, item, spider):
         #1.链接数据库
         #2.执行sql语句
         sql = ‘insert into qiubai values("%s","%s")‘%(item[‘author‘],item[‘content‘])
         self.cursor = self.conn.cursor()
         #执行事务
         try:
             self.cursor.execute(sql)
             self.conn.commit()
         except Exception as e:
             print(e)
             self.conn.rollback()
 ?
         return item
     def close_spider(self,spider):
         print(‘爬虫结束‘)
         self.cursor.close()
         self.conn.close()

- settings.py

 ITEM_PIPELINES = {
     ‘qiubaiPro.pipelines.QiubaiproPipelineByMysql‘: 300,
 }

2.2 基于redis的管道存储

在管道文件里将item对象中的数据值存储到了磁盘中,如果将item数据写入redis数据库的话,只需要将上述案例中的管道文件修改成如下形式:

 # Define your item pipelines here
 #
 # Don‘t forget to add your pipeline to the ITEM_PIPELINES setting
 # See: https://doc.scrapy.org/en/latest/topics/item-pipeline.html
 ?
 import redis
 ?
 class QiubaiproPipelineByRedis(object):
     conn = None
     def open_spider(self,spider):
         print(‘开始爬虫‘)
         #创建链接对象
         self.conn = redis.Redis(host=‘127.0.0.1‘,port=6379)
     def process_item(self, item, spider):
         dict = {
             ‘author‘:item[‘author‘],
             ‘content‘:item[‘content‘]
         }
         #写入redis中
         self.conn.lpush(‘data‘, dict)
         return item

- pipelines.py文件

 ITEM_PIPELINES = {
     ‘qiubaiPro.pipelines.QiubaiproPipelineByRedis‘: 300,
 }
img

- 如果最终需要将爬取到的数据值一份存储到磁盘文件,一份存储到数据库中,则应该如何操作scrapy?  

- 答:管道文件中的代码为

 #该类为管道类,该类中的process_item方法是用来实现持久化存储操作的。
 class DoublekillPipeline(object):
 ?
     def process_item(self, item, spider):
         #持久化操作代码 (方式1:写入磁盘文件)
         return item
 ?
 #如果想实现另一种形式的持久化操作,则可以再定制一个管道类:
 class DoublekillPipeline_db(object):
 ?
     def process_item(self, item, spider):
         #持久化操作代码 (方式1:写入数据库)
         return item
img

在settings.py开启管道操作代码为:

 #下列结构为字典,字典中的键值表示的是即将被启用执行的管道文件和其执行的优先级。
 ITEM_PIPELINES = {
    ‘doublekill.pipelines.DoublekillPipeline‘: 300,
     ‘doublekill.pipelines.DoublekillPipeline_db‘: 200,
 }
 ?
 #上述代码中,字典中的两组键值分别表示会执行管道文件中对应的两个管道类中的process_item方法,实现两种不同形式的持久化操作。

3. 总结

 1.
     pip install wheel
     pip install twisted
     pip install pywin32
     pip install scrapy
 2.
     scrapy startproject ProName
     cd ProName
     scrapy genspider xxx www.xxx.com
 ?
 3.目录结构:
     spider:放置一个爬虫文件
     item:
         xxx = Filed()
     pipeline:
         - process_item():
         - open_spider()
         - close_spider()
     setings:
 4.爬虫文件:
     - name
     - start_urls:
     - parse(self,response):
     - xpath():列表元素Selector对象. extract()
     - 持久化存储:
         - 终端指令: 只可以将parse方法的返回值进行本地文件的持久化存储
                 - scrapy crawl xxx -o ./xxx.csv
         - 管道:
             1.数据解析
             2.将解析到的数据封装到item类型的对象
             3.通过yield向管道提交item对象
             4.在管道的process_item方法中执行io操作,进行持久化存储
             5.在配置文件中开启管道
             注意:process_item方法中返回值的作用:
         - 手动请求的发送:
             - yiled scrapy.Request(url,callback)

  

原文地址:https://www.cnblogs.com/yzg-14/p/12204031.html

时间: 2024-11-03 22:09:20

Scrapy持久化存储的相关文章

爬虫--使用scrapy爬取糗事百科并在txt文件中持久化存储

工程目录结构 spiders下的first源码 # -*- coding: utf-8 -*- import scrapy from firstBlood.items import FirstbloodItem class FirstSpider(scrapy.Spider): #爬虫文件的名称 #当有多个爬虫文件时,可以通过名称定位到指定的爬虫文件 name = 'first' #allowed_domains 允许的域名 跟start_url互悖 #allowed_domains = ['w

Scrapy框架基础应用和持久化存储

一.Scrapy框架的基础应用 1.Scrapy的概念 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架,非常出名,非常强悍.所谓的框架就是一个已经被集成了各种功能(高性能异步下载,队列,分布式,解析,持久化等)的具有很强通用性的项目模板. 2.安装 windows: a. pip3 install wheel b. 下载twisted http://www.lfd.uci.edu/~gohlke/pythonlibs/#twisted c. 进入下载目录,执行 pip3 in

scrapy 框架持久化存储

1.基于终端的持久化存储 保证爬虫文件的parse方法中有可迭代类型对象(通常为列表或字典)的返回,该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化操作. # 执行输出指定格式进行存储:将爬到的数据写入不同格式的文件中进行存储 scrapy crawl <爬虫名称> -o xxx.json scrapy crawl <爬虫名称> -o xxx.xml scrapy crawl <爬虫名称> -o xxx.csv 2.基于管道的持久化存储 scrapy框架中已

【Scrapy框架持久化存储】 -- 2019-08-08 20:40:10

原文: http://106.13.73.98/__/138/ 基于终端指令的持久化存储 前提:保证爬虫文件中的parse方法的返回值为可迭代数据类型(通常为list/dict). 该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化存储. 执行如下命令进行持久化存储: scrapy crawl 应用名称 -o xx.文件格式 其支持的文件格式有:'json', 'jsonlines', 'jl', 'csv', 'xml', 'marshal', 'pickle' 基于管道的持久化存储

Scrapy框架实现持久化存储

硬盘存储 (1) 基于终端指令 * 保证parse方法返回一个可迭代类型的对象(存储解析到页面内容) * 使用终端指定完成数据存储到磁盘文件的操作     scrapy crawl 爬虫文件名称 -o 磁盘文件.后缀 def parse(self, response): # 建议使用xpath进行解析(框架集成了xpath解析的接口) div_list = response.xpath('//div[@id="content-left"]/div ') # 存储解析到的页面数据 dat

【Scrapy框架持久化存储】 &#588437;

原文: http://blog.gqylpy.com/gqy/363 " 基于终端指令的持久化存储 前提:保证爬虫文件中的parse方法的返回值为可迭代数据类型(通常为list/dict). 该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化存储. 执行如下命令进行持久化存储: scrapy crawl 应用名称 -o xx.文件格式 其支持的文件格式有:'json', 'jsonlines', 'jl', 'csv', 'xml', 'marshal', 'pickle' 基于管道的

python网络爬虫——scrapy框架持久化存储

1.基于终端指令的持久化存储 保证爬虫文件的parse方法中有可迭代类型对象(通常为列表or字典)的返回,该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化操作. 执行输出指定格式进行存储:将爬取到的数据写入不同格式的文件中进行存储 scrapy crawl 爬虫名称 -o xxx.json scrapy crawl 爬虫名称 -o xxx.xml scrapy crawl 爬虫名称 -o xxx.csv 2.基于管道的持久化存储 scrapy框架中已经为我们专门集成好了高效.便捷的持

爬虫学习 11.scrapy框架持久化存储

爬虫学习 11.scrapy框架持久化存储 基于终端指令的持久化存储 基于管道的持久化存储 今日详情 1.基于终端指令的持久化存储 保证爬虫文件的parse方法中有可迭代类型对象(通常为列表or字典)的返回,该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化操作. 执行输出指定格式进行存储:将爬取到的数据写入不同格式的文件中进行存储 scrapy crawl 爬虫名称 -o xxx.json scrapy crawl 爬虫名称 -o xxx.xml scrapy crawl 爬虫名称

Scrapy基于终端指令的持久化存储

保证爬虫文件的parse方法中有可迭代类型对象(通常为列表or字典)的返回,该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化操作. scrapy使用流程: 创建工程: scrapy startproject ProName 进入工程目录: cd ProName 创建爬虫文件: scrapy genspider spiderName www.xxx.com 编写相关操作代码 执行工程: scrapy crawl spiderName 执行指令: 执行输出指定格式进行存储:将爬取到的数据