Page Object pattern for Scrapy
Project description
scrapy-poet is the web-poet Page Object pattern implementation for Scrapy. scrapy-poet allows to write spiders where extraction logic is separated from the crawling one. With scrapy-poet is possible to make a single spider that supports many sites with different layouts.
Read the documentation for more information.
License is BSD 3-clause.
Documentation: https://scrapy-poet.readthedocs.io
Source code: https://github.com/scrapinghub/scrapy-poet
Issue tracker: https://github.com/scrapinghub/scrapy-poet/issues
Quick Start
Installation
pip install scrapy-poet
Requires Python 3.8+ and Scrapy >= 2.6.0.
Usage in a Scrapy Project
Add the following inside Scrapy’s settings.py file:
DOWNLOADER_MIDDLEWARES = {
"scrapy_poet.InjectionMiddleware": 543,
}
SPIDER_MIDDLEWARES = {
"scrapy_poet.RetryMiddleware": 275,
}
Developing
Setup your local Python environment via:
pip install -r requirements-dev.txt
pre-commit install
Now everytime you perform a git commit, these tools will run against the staged files:
black
isort
flake8
You can also directly invoke pre-commit run –all-files or tox -e linters to run them without performing a commit.
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
Hashes for scrapy_poet-0.17.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4d6eb1db872604656e9777d7eea9033b8b6146bfedbd4b6079db970964c15a4e |
|
MD5 | 75129feadcafff4a0a0f0130d5e045cd |
|
BLAKE2b-256 | f10fd01b1f94e2654a9dd52a6aa2b41aed53467f44c22bdce6df9698663cfc43 |