前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Scrapy(5)item 之详解

Scrapy(5)item 之详解

作者头像
公众号---人生代码
发布于 2020-05-16 14:10:50
发布于 2020-05-16 14:10:50
98100
代码可运行
举报
文章被收录于专栏:人生代码人生代码
运行总次数:0
代码可运行

我来了,今天又烦恼了一会,又去河边听水声了,回来想清楚了,感觉还是太浮躁了,得静下心来好好读书了,事业,副业还是得寻找,希望不要给自己太大压力吧

还是告诉自己,当我的才华还撑不起我的野心时,我应该静下心来学习,当我的经济还撑不起我的理想时,我应该脚踏实地得工作,脚踏实地的投资理财,不断的买入资产,还是定期投入比特币,以太坊,中证500,恒生指数,红利指数吧,反正这些指数现在都在低估阶段,总感觉今年绝对是充满时机的一年

今天得主题讲解 item

抓取的主要目标是从非结构化源(通常是网页)中提取结构化数据。Scrapy蜘蛛可以像Python一样返回提取的数据。虽然方便和熟悉,但Python缺乏结构:很容易在字段名称中输入拼写错误或返回不一致的数据,尤其是在具有许多蜘蛛的较大项目中。

为了定义通用输出数据格式,Scrapy提供了Item类。 Item对象是用于收集抓取数据的简单容器。它们提供类似字典的 API,并具有用于声明其可用字段的方便语法。

各种Scrapy组件使用Items提供的额外信息:导出器查看声明的字段以确定要导出的列,可以使用Item字段元数据自定义序列化,trackref 跟踪Item实例以帮助查找内存泄漏(请参阅使用trackref调试内存泄漏)等。

声明项目

使用简单的类定义语法和Field 对象声明项。这是一个例子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import scrapy

class Product(scrapy.Item):
    name = scrapy.Field()
    price = scrapy.Field()
    stock = scrapy.Field()
    last_updated = scrapy.Field(serializer=str)

注意

那些熟悉Django的人会注意到Scrapy Items被宣告类似于Django Models,除了Scrapy Items更简单,因为没有不同字段类型的概念。

项目字段

Field对象用于指定每个字段的元数据。例如,last_updated上面示例中说明的字段的序列化函数。

您可以为每个字段指定任何类型的元数据。Field对象接受的值没有限制。出于同样的原因,没有所有可用元数据键的参考列表。Field对象中定义的每个键可以由不同的组件使用,只有那些组件知道它。您也可以根据Field自己的需要定义和使用项目中的任何其他 键。Field对象的主要目标是提供一种在一个地方定义所有字段元数据的方法。通常,行为取决于每个字段的那些组件使用某些字段键来配置该行为。您必须参考其文档以查看每个组件使用的元数据键。

请务必注意,Field用于声明项目的对象不会保留为类属性。相反,可以通过Item.fields属性访问它们。

使用项目

以下是使用上面声明的Product项目对项目执行的常见任务的一些示例 。您会注意到API与dict API非常相似。

创建项目

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> product = Product(name='Desktop PC', price=1000)
>>> print product
Product(name='Desktop PC', price=1000)

获取字段值

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> product['name']
Desktop PC
>>> product.get('name')
Desktop PC

>>> product['price']
1000

>>> product['last_updated']
Traceback (most recent call last):
    ...
KeyError: 'last_updated'

>>> product.get('last_updated', 'not set')
not set

>>> product['lala'] # getting unknown field
Traceback (most recent call last):
    ...
KeyError: 'lala'

>>> product.get('lala', 'unknown field')
'unknown field'

>>> 'name' in product  # is name field populated?
True

>>> 'last_updated' in product  # is last_updated populated?
False

>>> 'last_updated' in product.fields  # is last_updated a declared field?
True

>>> 'lala' in product.fields  # is lala a declared field?
False

设定字段值

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> product['last_updated'] = 'today'
>>> product['last_updated']
today

>>> product['lala'] = 'test' # setting unknown field
Traceback (most recent call last):
    ...
KeyError: 'Product does not support field: lala'

访问所有填充值

要访问所有填充值,只需使用典型的dict API:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> product.keys()
['price', 'name']

>>> product.items()
[('price', 1000), ('name', 'Desktop PC')]

其他常见任务

复制项目:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> product2 = Product(product)
>>> print product2
Product(name='Desktop PC', price=1000)

>>> product3 = product2.copy()
>>> print product3
Product(name='Desktop PC', price=1000)

从项目创建dicts:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> dict(product) # create a dict from all populated values
{'price': 1000, 'name': 'Desktop PC'}

从dicts创建项目:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> Product({'name': 'Laptop PC', 'price': 1500})
Product(price=1500, name='Laptop PC')
>>> Product({'name': 'Laptop PC', 'lala': 1500}) # warning: unknown field in dict
Traceback (most recent call last):
    ...
KeyError: 'Product does not support field: lala'

扩展项目

您可以通过声明原始Item的子类来扩展Items(以添加更多字段或更改某些字段的某些元数据)。

例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class DiscountedProduct(Product):
    discount_percent = scrapy.Field(serializer=str)
    discount_expiration_date = scrapy.Field()

您还可以使用先前的字段元数据扩展字段元数据,并附加更多值或更改现有值,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class SpecificProduct(Product):
    name = scrapy.Field(Product.fields['name'], serializer=my_serializer)

这会添加(或替换)字段的serializer元数据键name,保留所有先前存在的元数据值。

物品对象

classscrapy.item.Item([arg ])

返回一个可选的从给定参数初始化的新Item。

Items复制标准dict API,包括其构造函数。Items提供的唯一附加属性是:

fields

包含此Item的所有已声明字段的字典,不仅包括已填充的字段。键是字段名称,值是Item声明中Field使用的 对象。

字段对象

classscrapy.item.Field([arg ])

Field班只是一个别名内置的字典类,并没有提供任何额外功能或属性。换句话说, Field对象是普通的Python dicts。一个单独的类用于支持 基于类属性的项声明语法。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-04-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 CryptoCode 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
一次非常有意思的SQL优化经历
发现没有用到索引,type全是ALL,那么首先想到的就是建立一个索引,建立索引的字段当然是在where条件的字段。
哲洛不闹
2018/09/19
4970
一次非常有意思的SQL优化经历
一次非常有意思的 SQL 优化经历:从 30248.271s 到 0.001s
发现没有用到索引,type全是ALL,那么首先想到的就是建立一个索引,建立索引的字段当然是在where条件的字段。
芋道源码
2019/05/23
4020
一次非常有意思的 SQL 优化经历: 从 30248.271s 到 0.001s
链接:https://www.cnblogs.com/tangyanbo/p/4462734.html
Java小咖秀
2020/07/07
3460
一次非常有意思的 SQL 优化经历: 从 30248.271s 到 0.001s
SQL优化的魅力!从 30248s 到 0.001s
点击上方“芋道源码”,选择“设为星标” 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏 原创 | Java 2021 超神之路,很肝~ 中文详细注释的开源项目 RPC 框架 Dubbo 源码解析 网络应用框架 Netty 源码解析 消息中间件 RocketMQ 源码解析 数据库中间件 Sharding-JDBC 和 MyCAT 源码解析 作业调度中间件 Elastic-Job 源码解析 分布式事务中间件 TCC-Transaction
芋道源码
2022/08/29
3310
SQL优化的魅力!从 30248s 到 0.001s
一波骚操作,我把 SQL 执行效率提高了 10,000,000 倍
发现没有用到索引,type全是ALL,那么首先想到的就是建立一个索引,建立索引的字段当然是在where条件的字段。
Java学习录
2019/11/12
7340
一次非常有趣的 SQL 优化经历
发现没有用到索引,type 全是 ALL ,那么首先想到的就是建立一个索引,建立索引的字段当然是在 where 条件的字段了。
良月柒
2019/03/26
4520
MySQL经典50题:面试必备
标题 MySQL经典50题解析及答案 作者 Peter 微信 756803877 公众号 尤而小屋 时间 2021-09-02 MySQL经典50题解析及答案 下面是网传经典的MySQL50题的习题及参考答案💪,供参考和学习,有更好的方法或者不恰当的地方,欢迎提出来 <!--MORE--> 题目1 题目要求 查询"01"课程比"02"课程成绩高的学生的信息及课程分数 SQL实现 -- 方法1 select a.* ,b.s_score as 1_score ,c.s_score
皮大大
2021/09/02
1.9K0
MySQL经典50题:面试必备
50道SQL面试题
9、查询所有课程成绩都小于60分的学生的学号、姓名(有意思,如果不用max可能难度不小)
九转成圣
2024/04/10
1320
重新学习MySQL数据库12:从实践sql语句优化开始
本系列文章将整理到我在GitHub上的《Java面试指南》仓库,更多精彩内容请到我的仓库里查看
Java技术江湖
2019/12/02
5390
MySQL50-10-第36-40题
本文中介绍的是第36-40题目,涉及到的知识点都是多表的连接查询,需要指定不同的条件。5个题目分别是:
皮大大
2021/03/01
2850
MySQL50-10-第36-40题
擅用子查询,让复杂问题简单化
第一步:根据需要查询的最终结果确认所需用到的表:"学生信息及课程分数",需要用到学生信息表与成绩表;
数据STUDIO
2021/06/24
5310
MySQL50题-分类总结
笔者最近将网上流传的MySQL数据库经典50题进行了练习,梳理了一份自己的练习成果。下图是MySQL练习题中涉及到的4张表和它们的具体字段:
皮大大
2021/03/01
8190
MySQL50题-分类总结
MySQL练习题
用户11097514
2024/05/30
1130
Java后端面试经验总结分享(一)
跟大部分公司类似,先做一份笔试题,题目都比较简单,基本都写完了。我把题目以及答案列在下面一下,给自己做一下总结的,也分享给一些需要的小伙伴,下面答案是我根据网上的进行总结的。
朱季谦
2019/09/29
5110
Java面试——SQL语句题
【1】查询"01"课程比"02"课程成绩高的学生的信息及课程分数:当对一张表中的一列数据比较时,应当将一张表拆分为两张表;
Java架构师必看
2021/05/14
6080
小学生SQL50题
已知有如下4张表: 学生表: student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 课程表: course(c_id,c_name,t_id) – –课程编号, 课程名称, 教师编号 教师表: teacher(t_id,t_name) –教师编号,教师姓名 成绩表: ccore(s_id,c_id,s_s_score) –学生编号,课程编号,分数 要求,根据以上信息按照下面要求写出对应的SQL语句。看看你能答对几道题?
大数据真好玩
2019/08/08
8590
相关推荐
一次非常有意思的SQL优化经历
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档