Fast asynchronous web scraper with minimalist API.
Project description
Hypotonic
Fast asynchronous web scraper with minimalist API inspired by awesome node-osmosis.
Hypotonic provides SQLAlchemy-like command chaining DSL to define HTML scrapers. Everything is executed asynchronously via asyncio
and all dependencies are pure Python. Supports querying by CSS selectors with Scrapy's pseudo-attributes. XPath is not supported due to libxml
requirement.
Hypotonic does not natively execute JavaScript on websites and it is recommended to use prerender.
Installing
Hypotonic requires Python 3.6+.
pip install hypotonic
Example
from hypotonic import Hypotonic
data, errors = (
Hypotonic()
.get('http://books.toscrape.com/')
.paginate('.next a::attr(href)', 5)
.find('.product_pod h3')
.set('title')
.follow('a::attr(href)')
.set({'price': '.price_color',
'availability': 'p.availability'})
.data()
)
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
hypotonic-0.0.12.tar.gz
(5.3 kB
view hashes)
Built Distribution
Close
Hashes for hypotonic-0.0.12-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8b873e48449b5798a7712578fd08a9a131a0d6a0206239b8c98cdb5df44e0c3d |
|
MD5 | 439a993c325b4001cbf6617a85097754 |
|
BLAKE2b-256 | f8a6bc94920bb634e970a2d97d94a609c59af927115bbfbb173cc3b09204865f |