Common interface for Scrapy items
Project description
itemadapter
The ItemAdapter class is a wrapper for data container objects, providing a
common interface to handle objects of different types in an uniform manner,
regardless of their underlying implementation.
This package started as an initiative to support dataclass objects as items
[1]. It was extracted out to a standalone package
in order to allow it to be used independently.
Currently supported types are:
- Classes that implement the
MutableMappinginterface, including but not limited to: dataclass-based classesattrs-based classes
Requirements
- Python 3.5+
dataclasses(stdlib in Python 3.7+, or its backport in Python 3.6): optional, needed to interact withdataclass-based itemsattrs: optional, needed to interact withattrs-based items
API
ItemAdapter class
class itemadapter.adapter.ItemAdapter(item: Any)
ItemAdapter implements the
MutableMapping interface,
providing a dict-like API to manipulate data for the object it wraps
(which is modified in-place).
Two additional methods are available:
get_field_meta(field_name: str) -> MappingProxyType
Return a MappingProxyType
object with metadata about the given field, or raise TypeError if the item class does not
support field metadata.
The returned value is taken from the following sources, depending on the item type:
dataclasses.field.metadatafordataclass-based itemsattr.Attribute.metadataforattrs-based itemsscrapy.item.Fieldforscrapy.item.Items
field_names() -> List[str]
Return a list with the names of all the defined fields for the item.
is_item function
itemadapter.utils.is_item(obj: Any) -> bool
Return True if the given object belongs to one of the supported types,
False otherwise.
Metadata support
scrapy.item.Item, dataclass and attrs objects allow the inclusion of
arbitrary field metadata, which can be retrieved with the
ItemAdapter.get_field_meta method. The definition procedure depends on the
underlying type.
scrapy.item.Item objects
>>> from scrapy.item import Item, Field
>>> from itemadapter import ItemAdapter
>>> class InventoryItem(Item):
... name = Field(serializer=str)
... value = Field(serializer=int, limit=100)
...
>>> adapter = ItemAdapter(InventoryItem(name="foo", value=10))
>>> adapter.get_field_meta("name")
mappingproxy({'serializer': <class 'str'>})
>>> adapter.get_field_meta("value")
mappingproxy({'serializer': <class 'int'>, 'limit': 100})
dataclass objects
>>> from dataclasses import dataclass, field
>>> @dataclass
... class InventoryItem:
... name: str = field(metadata={"serializer": str})
... value: int = field(metadata={"serializer": int, "limit": 100})
...
>>> adapter = ItemAdapter(InventoryItem(name="foo", value=10))
>>> adapter.get_field_meta("name")
mappingproxy({'serializer': <class 'str'>})
>>> adapter.get_field_meta("value")
mappingproxy({'serializer': <class 'int'>, 'limit': 100})
attrs objects
>>> import attr
>>> @attr.s
... class InventoryItem:
... name = attr.ib(metadata={"serializer": str})
... value = attr.ib(metadata={"serializer": int})
...
>>> adapter = ItemAdapter(InventoryItem(name="foo", value=10))
>>> adapter.get_field_meta("name")
mappingproxy({'serializer': <class 'str'>})
>>> adapter.get_field_meta("value")
mappingproxy({'serializer': <class 'int'>})
Examples
scrapy.item.Item objects
>>> from scrapy.item import Item, Field
>>> from itemadapter import ItemAdapter
>>> class InventoryItem(Item):
... name = Field()
... price = Field()
...
>>> item = InventoryItem(name="foo", price=10)
>>> adapter = ItemAdapter(item)
>>> adapter.item is item
True
>>> adapter["name"]
'foo'
>>> adapter["name"] = "bar"
>>> adapter["price"] = 5
>>> item
{'name': 'bar', 'price': 5}
dict
>>> from itemadapter import ItemAdapter
>>> item = dict(name="foo", price=10)
>>> adapter = ItemAdapter(item)
>>> adapter.item is item
True
>>> adapter["name"]
'foo'
>>> adapter["name"] = "bar"
>>> adapter["price"] = 5
>>> item
{'name': 'bar', 'price': 5}
dataclass objects
>>> from dataclasses import dataclass
>>> from itemadapter import ItemAdapter
>>> @dataclass
... class InventoryItem:
... name: str
... price: int
...
>>> item = InventoryItem(name="foo", price=10)
>>> adapter = ItemAdapter(item)
>>> adapter.item is item
True
>>> adapter["name"]
'foo'
>>> adapter["name"] = "bar"
>>> adapter["price"] = 5
>>> item
InventoryItem(name='bar', price=5)
attrs objects
>>> import attr
>>> from itemadapter import ItemAdapter
>>> @attr.s
... class InventoryItem:
... name = attr.ib()
... price = attr.ib()
...
>>> item = InventoryItem(name="foo", price=10)
>>> adapter = ItemAdapter(item)
>>> adapter.item is item
True
>>> adapter["name"]
'foo'
>>> adapter["name"] = "bar"
>>> adapter["price"] = 5
>>> item
InventoryItem(name='bar', price=5)
[1]: dataclass objects as items:
issue and
pull request
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file itemadapter-0.0.4.tar.gz.
File metadata
- Download URL: itemadapter-0.0.4.tar.gz
- Upload date:
- Size: 6.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1ab9a8292cc0c2a8adae9ecd2dd192c26da222effd042a5a97dcc5d045da300d
|
|
| MD5 |
96ff16652f4a395fc7fc683a09fe937e
|
|
| BLAKE2b-256 |
26b4cf216330afac2019546fa8b6f910b14198e1f667c65c1e0d988ba8cc6b67
|
File details
Details for the file itemadapter-0.0.4-py3-none-any.whl.
File metadata
- Download URL: itemadapter-0.0.4-py3-none-any.whl
- Upload date:
- Size: 6.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
be9fa73ba8ff035aea7fa99c497bb7783a1c6916b073aa4d8e5a18f8a46904a5
|
|
| MD5 |
ba9510f6ce7b2c8891c4ae5e79f8fafb
|
|
| BLAKE2b-256 |
aaf9015f09218759106f235450e56f52cd2ce7b83c63c4a7cdfe33e1d65185fc
|