在Scrapy框架中的items.py的作用

  1.可以预先定义好要爬取的字段     items.py

  1. import scrapy
  2.  
  3.  
  4. class TencentItem(scrapy.Item):
  5. # define the fields for your item here like:
  6. # name = scrapy.Field()
  7. """定义好字段,并不代表真正的值,只是占一个位置,用的时候直接赋值就行"""
  8. position = scrapy.Field()
  9. category = scrapy.Field()
  10. date = scrapy.Field()

2. 把字段定义好之后 ,就可以在爬虫中进行使用

在用的时候, item的键名要和在items.py里面定义好的字段名称一致

  1. import scrapy
  2. ''' 导入不同爬虫的类字段'''
  3. from tencent.items import TencentItem,TencentItem2,TencentItem3
  4.  
  5. class TencentSpiderSpider(scrapy.Spider):
  6. name = 'tencent_spider'
  7. allowed_domains = ['tencent.com']
  8. start_urls = ['https://hr.tencent.com/position.php']
  9.  
  10. def parse(self, response):
  11. tr_list = response.xpath("//table[@class='tablelist']//tr")[1:-1]
  12. for tr in tr_list:
  13. """使用定义好的类"""
  14. item = TencentItem()
  15. """里面的键名,必须提前在items里面定义好之后才能用"""
  16. item["position"] = tr.xpath("./td/a/text()").extract_first()
  17. item["category"] = tr.xpath(".//td[2]/text()").extract_first()
  18. item["date"] = tr.xpath(".//td[5]/text()").extract_first()
  19. yield item

3. 如果想在pipelines.py中使用的方法是大同小异,只是在进行处理的时候item传过来的是一个类对象,要对其进行相应        的  转化

  1. '''分别导入不同爬虫的字段类'''
  2. from tencent.items import TencentItem, TencentItem2, TencentItem3
  3.  
  4.  
  5. class TencentPipeline(object):
  6. def process_item(self, item, spider):
  7. """使用item的时候这里接收的是TencentItem类的对象,我们可以把它转化字典"""
  8. print(dict(item))
  9. '''针对与不同的爬虫字段类的对象,做不同的处理'''
  10. return item

4. 这样做有什么好处呢,个人理解:

(1)  可以直接看items.py,可以看出来要爬取那些字段

(2) 防止我们在item["键名"]  输入键名的时候输入错误

有多个爬虫时Item的处理

例如有个腾讯爬虫、有个京东爬虫,怎样处理

1. 在items.py里面创建不同的类,分别保存各自的字段

  1. class TencentItem(scrapy.Item):
  2. """腾讯爬虫要爬取的字段"""
  3. """定义好字段,并不代表真正的值,只是占一个位置,用的时候直接赋值就行"""
  4. position = scrapy.Field()
  5. category = scrapy.Field()
  6. date = scrapy.Field()
  7.  
  8. class JdItem(scrapy.Item):
  9. """京东爬虫要爬取的字段"""
  10. """定义好字段,并不代表真正的值,只是占一个位置,用的时候直接赋值就行"""
  11. position = scrapy.Field()
  12. category = scrapy.Field()
  13. date = scrapy.Field()

2. 然后在不同的爬虫程序里使用对应的类即可

在腾讯的爬虫里 ,  导入和使用

  1. import scrapy
  2. # 导入不同爬虫的类字段
  3. from tencent.items import TencentItem
  4.  
  5. class TencentSpiderSpider(scrapy.Spider):
  6. pass
  7. def parse(self, response):
  8. pass
  9. for tr in tr_list:
  10. """使用定义好的腾讯爬虫的类的字段"""
  11. item = TencentItem()
  12. yield item

在京东的爬虫中,可以这样使用

  1. import scrapy
  2. # 导入不同爬虫的类字段
  3. from JD.items import JdItem
  4.  
  5. class JdSpiderSpider(scrapy.Spider):
  6. pass
  7. def parse(self, response):
  8. pass
  9. for tr in tr_list:
  10. """使用定义好的腾讯爬虫的类的字段"""
  11. item = JdItem()
  12. yield item

3. 对于多个爬虫,在pipelines,py中可以进行判断,分别对不同的爬虫的字段进行不同的处理

    isinstance() 函数来判断一个对象是否是一个已知的类型

  1. '''分别导入不同爬虫的字段类'''
  2. from tencent.items import TencentItem, JdItem2
  3.  
  4.  
  5. class TencentPipeline(object):
  6. def process_item(self, item, spider):
  7. '''针对与不同的爬虫字段类的对象,做不同的处理'''
  8. if isinstance(item, TencentItem):
  9. pass
  10. if isinstance(item, JdItem2):
  11. pass
  12. return item

Scrapy框架的学习(6.item介绍以及items的使用(提前定义好字段名))转载https://blog.csdn.net/wei18791957243/article/details/86259688的更多相关文章

  1. K8S 使用NFS 创建PV和PVC的例子 学习From https://blog.csdn.net/xts_huangxin/article/details/51494472

    1. 获取资料 网址: https://blog.csdn.net/xts_huangxin/article/details/51494472  感谢原作者 这里面 按照自己的机器情况进行了学习模仿 ...

  2. Android 学习路线图(转载自https://blog.csdn.net/lixuce1234/article/details/77947405)

    程序设计 一.java (a)基本语法(如继承.异常.引用.泛型等) Java核心技术 卷I(适合入门) 进阶 Effective Java中文版(如何写好的Java代码) Java解惑 (介绍烂Ja ...

  3. OpenGL学习脚印: uniform blocks在着色器中的使用 转自https://blog.csdn.net/wangdingqiaoit/article/details/52717963

    写在前面 目前,我们在着色器中要传递多个uniform变量时,总是使用多个uniform,然后在主程序中设置这些变量的值:同时如果要在多个shader之间共享变量,例如投影矩阵projection和视 ...

  4. scala学习(idea编译过程https://blog.csdn.net/guiying712/article/details/68947747)

    scala官网 https://www.scala-lang.org/ 菜鸟教程学习 http://www.runoob.com/scala/scala-basic-syntax.html w3sch ...

  5. Bootstrap学习4--Table样式(转载:https://blog.csdn.net/Fanbin168/article/details/53208869)

    备注:最新Bootstrap手册:http://www.jqhtml.com/bootstraps-syntaxhigh/index.html 将<table>标签添加class=‘tab ...

  6. 学习mongoDB的一些感受(转自:http://blog.csdn.net/liusong0605/article/details/11581019)

    曾经使用过mongoDB来保存文件,最一开始,只是想总结一下在开发中如何实现文件与mongoDB之间的交互.在此之前,并没有系统的了解过mongoDB,虽然知道我们用它来存储文件这些非结构化数据,但是 ...

  7. jbpm的学习 出处http://blog.csdn.net/hxirui/article/details/1221911

    jbpm入门例子 分类: opensourse2006-09-14 11:30 37308人阅读 评论(22) 收藏 举报 jbpmhibernate数据库oraclemysqltransition ...

  8. Mapreduce之序列化框架(转自http://blog.csdn.net/lastsweetop/article/details/9376495)

    框架简介 MapReduce仅仅可以支持Writable做key,value吗?答案是否定的.事实上,一切类型都是支持的,只需满足一个小小的条件:每个类型是以二进制流的形式传输.为此Hadoop提供了 ...

  9. H5学习系列之文件读取API--本文转自http://blog.csdn.net/jackfrued/article/details/8967667

    HTML5定义了FileReader作为文件API的重要成员用于读取文件,根据W3C的定义,FileReader接口提供了读取文件的方法和包含读取结果的事件模型. FileReader的使用方式非常简 ...

随机推荐

  1. WOW.js和animate.css让页面滚动时显示动画

    官网:http://mynameismatthieu.com/WOW/ bootstrap CDN服务:http://www.bootcdn.cn/wow/ 1.wow.js 实现了在网页滚动时的动画 ...

  2. 查看和修改 mysql库、表、字段编码

    查看编码 查看数据库编码. show variables like '%char%'; 查看表编码 show create table <表名>; 例:show create table ...

  3. Netty:option和childOption参数设置说明

    Channel配置参数 (1).通用参数 CONNECT_TIMEOUT_MILLIS :   Netty参数,连接超时毫秒数,默认值30000毫秒即30秒. MAX_MESSAGES_PER_REA ...

  4. 运营商挂时长神器,批量导入账号,导出账号状态,随机修改MAC地址

    话不多说,直接上图 可批量导入账号,同时修改广域网口MAC地址 导出账号状态,包括在线时长,MAC,IP地址等等

  5. ubuntu更改镜像源

    参考 https://blog.csdn.net/weixin_41762173/article/details/79480832 建议使用ustc.edu的源,其他例如清华的,阿里的连sublime ...

  6. zookeeper使用

    ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等.Zookeeper是hadoop的一个子项目,其 ...

  7. 更改了react-redux 官方网站的todolist结构

    最近在学习胡子大哈的react小书,内容讲的由浅入深,很值得react,react-redux小白一读. 废话不多说直接上地址:http://huziketang.mangojuice.top/boo ...

  8. MySQL-[SIGNAL/RESIGNAL/GET DIAGNOSTICS]的使用

    最近在做 SQL Server 到 MySQL 的迁移(migration),相较于对表和数据的迁移,最令人犯难的还是在功能性存储过程脚本的改写转换(convert),虽说 MySQL 如今是蓬勃发展 ...

  9. 使用isEmpty()报空指针异常

    使用isEmpty()是出现了空指针异常NullpointException: 原来isEmpty()用来判断一个变量是否已经初始化了,因为“”和new 的时候系统都会为其分配内存,不管是否有值,当为 ...

  10. layui---事件监听

    在使用layui的form表单做验证提交的时候,如果结合vue,或者是三级联动的时候,就需要做事件监听了. 具体语法: form.on('event(过滤器值)', callback); 可以用于监听 ...