专栏首页人生代码Scrapy(5)item 之详解

Scrapy(5)item 之详解

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

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

今天得主题讲解 item

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

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

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

声明项目

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

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非常相似。

创建项目

>>> product = Product(name='Desktop PC', price=1000)
>>> print product
Product(name='Desktop PC', price=1000)

获取字段值

>>> 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

设定字段值

>>> 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:

>>> product.keys()
['price', 'name']

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

其他常见任务

复制项目:

>>> product2 = Product(product)
>>> print product2
Product(name='Desktop PC', price=1000)

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

从项目创建dicts:

>>> dict(product) # create a dict from all populated values
{'price': 1000, 'name': 'Desktop PC'}

从dicts创建项目:

>>> 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(以添加更多字段或更改某些字段的某些元数据)。

例如:

class DiscountedProduct(Product):
    discount_percent = scrapy.Field(serializer=str)
    discount_expiration_date = scrapy.Field()

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

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。一个单独的类用于支持 基于类属性的项声明语法。

本文分享自微信公众号 - 志学Python(lijinwen1996329ken),作者:志学Python

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-04-28

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 图解算法系列(五): 堆栈

    下压栈(或简称栈)是一种基于后进后出的(LIFO)策咯的集合类型. 其中添加移除新项总发生在同一端。这一端通常称为“顶部”。与顶部对应的端称为“底部”。栈的例子...

    公众号---人生代码
  • 爬虫(107)Python 3.7的超酷新功能(接近一万字,请耐心享用,而且建议收藏)

    Python 3.7 正式发布!这个新的Python版本自2016年9月开始开发,现在我们所有人都可以享受核心开发人员辛勤工作的成果。

    公众号---人生代码
  • 使用组合自定义行为

    如果您的设计依赖于继承,则需要找到一种方法来更改对象的类型以更改其行为。对于组合,您只需要更改对象使用的策略

    公众号---人生代码
  • Java hashCode() 方法深入理解

    Java.lang.Object 有一个hashCode()和一个equals()方法,这两个方法在软件设计中扮演着举足轻重的角色。在一些类中覆写这两个方法以完...

    哲洛不闹
  • “Connection refused” vs “No route to host”

    曾经在http://blog.csdn.net/bisal/article/details/42496583这篇博文中提到一个端口连接的验证:

    bisal
  • python实战 fastapi利器之module(上)

    from typing import Any, Dict, List, Optional from pydantic import BaseModel, Fie...

    还是牛6504957
  • 慎点!这个鬼畜的小程序,听了容易上瘾......

    那些录音到底怎么来的?如果你也感到好奇,那么,知晓程序(微信号 zxcx0101)今天推荐小程序你一定会喜欢。

    知晓君
  • HanLP《自然语言处理入门》笔记--2.词典分词

    笔记转载于GitHub项目:https://github.com/NLP-LOVE/Introduction-NLP

    mantch
  • 寒武纪IPO二次问询结束,AI芯片新秀逆流而上,新基建时代未来可期

    这是一场振奋人心的、巨大的、系统性工程,将会对我国未来的发展产生巨大影响。而人工智能,显然已经成为这个巨大工程的重要组成部分,是「新基建」的「新基石」。

    新智元
  • 薛永刚:万物互联的安全新业态

    2018中国SD-WAN峰会已经圆满落幕,上元云安全CTO 薛永刚为我们带来主题演讲”万物互联的安全新业态”。

    SDNLAB

扫码关注云+社区

领取腾讯云代金券