Skip to main content

Lightweight tool for querying Online Judge statistics across multiple platforms

Project description

OJHunt Lite

A lightweight async Python tool for querying Online Judge (OJ) statistics across multiple platforms. Track your accepted problems and total submissions from competitive programming sites.

  • Async/concurrent requests via aiohttp
  • CLI and web interface
  • BSD-2 Licensed

CLI

Install once, use anywhere (pipx, uv tool, or pip):

pipx install ojhunt
# or: uv tool install ojhunt
# or: pip install ojhunt

Run directly from a clone (no install needed):

git clone https://github.com/Liu233w/ojhunt-lite
cd ojhunt-lite
uv run ojhunt tourist@codeforces

Run via container (no Python needed):

docker run --rm ghcr.io/liu233w/ojhunt-lite tourist@codeforces

Example output:

$ ojhunt tourist@codeforces tourist@atcoder
Querying CodeForces...
Querying AtCoder...
AtCoder done (1051 solved, 1.25s)
CodeForces done (2962 solved, 2.78s)

Total: 2962 solved / 6437 submissions

┏━━━━━━━━━━━━┳━━━━━━━━━━┳━━━━━━━━┳━━━━━━━━━━━━━┳━━━━━━━━━━━━┓
┃ Crawler     Username  Solved  Submissions  Status     ┃
┡━━━━━━━━━━━━╇━━━━━━━━━━╇━━━━━━━━╇━━━━━━━━━━━━━╇━━━━━━━━━━━━┩
│ CodeForces  tourist     2962         5386  OK (2.78s) │
│ AtCoder     tourist     1051         1051  OK (1.25s) │
└────────────┴──────────┴────────┴─────────────┴────────────┘
Completed: 2 OK, 0 failed (2.78s total)

Full CLI reference, login-required crawlers, and JSON output: docs/cli.md

Web Interface

The web interface is designed to be self-hosted. Clone the repo and deploy:

git clone https://github.com/Liu233w/ojhunt-lite
cd ojhunt-lite
uv sync
uv run fastapi run src/ojhunt/web/app.py --port 8080

Container images are available at ghcr.io/liu233w/ojhunt-lite — see docs/web.md.

Use Crawlers in Your Code

Add ojhunt as a project dependency:

uv add ojhunt
# or: pip install ojhunt

Sync (simplest):

from ojhunt.crawlers.codeforces import query
from ojhunt.crawlers import query_sync
result = query_sync(query, "tourist")
print(result.solved, result.submissions, result.solved_list)

Async (when you already have an event loop):

import asyncio, aiohttp
from ojhunt.crawlers.codeforces import query
from ojhunt.crawlers import CrawlerResult
async def main():
    async with aiohttp.ClientSession() as session:
        result = CrawlerResult.from_dict(await query(session, "tourist"))
        print(result.solved, result.submissions, result.solved_list)

asyncio.run(main())

query_sync and CrawlerResult work with any crawler in ojhunt.crawlers.*. Some crawlers (nit, uva) use a persistent label cache and require the full package — they cannot be used as standalone copied files.

Supported Platforms

See the src/ojhunt/crawlers/ directory. Archived crawlers (dead sites) are in archived_crawlers/.

Development

Adding crawlers, running tests, templates: docs/development.md

License

BSD 2-Clause License — see individual crawler files for full license text.

Credits

Lightweight Python rewrite of OJHunt (acm-statistics), originally inspired by 西北工业大学ACM查询系统 (npuacm.info) by Jiduo Zhang.

Special thanks to test account providers: @leoloveacm, @2013300262

Contributors ✨

Thanks goes to these wonderful people (emoji key):


Adelard Collins🔗
🐛

BackSlashDelta🔗
🐛

Bodhisatan_Yao🔗
🐛

Claude🔗
💻 🚇 ⚠️

Geekxiong🔗
🤔

Halorv🔗
🤔

Kido Zhang🔗
🚇 🤔

Liu233w🔗
💻 🤔 🚇 ⚠️

Meulsama🔗
🤔

Michael Xiang🔗
🐛

Zhao🔗
🐛

bLue🔗
💻

bluebear4🔗
🐛

ct🔗
🐛

flylai🔗
💻 🐛

fzu-h4cky🔗
🐛

wwawwaww🔗
🐛

zby🔗
🤔 🐛

This project follows the all-contributors specification. Contributions of any kind welcome!

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

ojhunt-2026.5.3.161658.tar.gz (2.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ojhunt-2026.5.3.161658-py3-none-any.whl (634.2 kB view details)

Uploaded Python 3

File details

Details for the file ojhunt-2026.5.3.161658.tar.gz.

File metadata

  • Download URL: ojhunt-2026.5.3.161658.tar.gz
  • Upload date:
  • Size: 2.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ojhunt-2026.5.3.161658.tar.gz
Algorithm Hash digest
SHA256 20f31456162e08b6b5dbece7336b84f457f58f6fb7d6a50056dca1c1dbeba912
MD5 cff70216634ed7bcaf3f7a9a1abb1e41
BLAKE2b-256 268bcfc9222a0db7a7dd352a33f7a5c61ebc25c1c3588c0b1ddb8b8d3247ee00

See more details on using hashes here.

Provenance

The following attestation bundles were made for ojhunt-2026.5.3.161658.tar.gz:

Publisher: release.yml on Liu233w/ojhunt-lite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ojhunt-2026.5.3.161658-py3-none-any.whl.

File metadata

File hashes

Hashes for ojhunt-2026.5.3.161658-py3-none-any.whl
Algorithm Hash digest
SHA256 cf97c99134f6349b7645fdaac4893341d57d64e1fd7844ce5f2533f59cacdb5e
MD5 2d7f8f6d9e4faa8a816855c2848f8533
BLAKE2b-256 e7b1dbec746ec55040d131870dee0ac563b29308c55dbe5703c835a56f3c707d

See more details on using hashes here.

Provenance

The following attestation bundles were made for ojhunt-2026.5.3.161658-py3-none-any.whl:

Publisher: release.yml on Liu233w/ojhunt-lite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page