This Python-based web scraper fetches content from URLs and exports it into Markdown and JSON formats, specifically designed for simplicity, extensibility, and for uploading JSON files to GPT models. Ideal for those looking to leverage web content for AI training or analysis. 🤖💡
(Or even better, use Docker! 🐳)
git clone https://github.com/obeone/crawler-to-md.git
cd crawler-to-md
pip install -r requirements.txt
python main.py --url https://www.example.com
- Scrapes web pages for content and metadata. 📄
- Filters links by base URL. 🔍
- Excludes URLs containing certain strings. ❌
- Automatically find links or can use a file of URLs to scrape. 🔗
- Rate limiting and delay 🕘
- Exports data to Markdown and JSON, ready for GPT uploads. 📤
- Exports each page as an individual Markdown file if
--export-individual
is used. 📝 - Uses SQLite for efficient data management. 📊
- Configurable via command-line arguments. ⚙️
- Docker support. 🐳
Python 3.12 and the following packages:
requests
beautifulsoup4
trafilatura
coloredlogs
Install with pip install -r requirements.txt
.
Start scraping with the following command:
python main.py --url <URL> [--output-folder ./output] [--cache-folder ./cache] [--base-url <BASE_URL>] [--exclude <KEYWORD_IN_URL>] [--title <TITLE>] [--urls-file <URLS_FILE>]
Options:
--url
,-u
: The starting URL. 🌍--urls-file
: Path to a file containing URLs to scrape, one URL per line. If '-', read from stdin. 📁--output-folder
,-o
: Where to save Markdown files (default:./output
). 📂--cache-folder
,-c
: Where to store the database (default:./cache
). 💾--base-url
,-b
: Filter links by base URL (default: URL's base). 🔎--title
,-t
: Final title of the markdown file. Defaults to the URL. 🏷️--exclude
,-e
: Exclude URLs containing this string (repeatable). ❌--export-individual
,-ei
: Export each page as an individual Markdown file. 📝--rate-limit
,-rl
: Maximum number of requests per minute (default: 0, no rate limit). ⏱️--delay
,-d
: Delay between requests in seconds (default: 0, no delay). 🕒
One of the --url
or --urls-file
is required.
By default, WARN
level is used. You can change it with the LOG_LEVEL
environment variable.
Run with Docker:
docker run --rm -v $(pwd)/output:/app/output -v cache:/app/cache ghcr.io/obeone/crawler-to-md --url <URL>
Build from source:
docker build -t crawler-to-md .
docker run --rm -v $(pwd)/output:/app/output crawler-to-md --url <URL>
Contributions are welcome! Feel free to submit pull requests or open issues. 🌟