The fastest web crawler written in Rust ported to nodejs.
Project description
spider-py
The spider project ported to Python.
The benches above were ran on a mac m1, spider on linux arm machines performs about 2-10x faster.
Getting Started
pip install spider_rs
import asyncio
from spider_rs import Website
async def main():
website = Website("https://choosealicense.com")
website.crawl()
print(website.get_links())
asyncio.run(main())
View the examples to learn more.
Development
Install maturin pipx install maturin
and python.
maturin develop
Benchmarks
View the benchmarks to see a breakdown between libs and platforms.
Test url: https://espn.com
libraries |
pages |
speed |
---|---|---|
spider(rust): crawl |
150,387 |
1m |
spider(nodejs): crawl |
150,387 |
153s |
spider(python): crawl |
150,387 |
186s |
scrapy(python): crawl |
49,598 |
1h |
crawlee(nodejs): crawl |
18,779 |
30m |
The benches above were ran on a mac m1, spider on linux arm machines performs about 2-10x faster.
Issues
Please submit a Github issue for any issues found.
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
spider_rs-0.0.21.tar.gz
(35.1 kB
view hashes)
Built Distribution
Close
Hashes for spider_rs-0.0.21-cp311-cp311-macosx_11_0_arm64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 89df49349d4bbee082afb24fa92dfaf1b5313cfbdb7c13806b4539df6bf6b1e7 |
|
MD5 | 56ab15c3bb003ef8ced30b32d24f571b |
|
BLAKE2b-256 | a8eff2ff580e6b77bbd8581a5f9116d00dfdf9b586e6c15c618f219652152d77 |