Skip to main content

Python SDK for the Polaris market data API

Project description

polaris-py

Python SDK for the Polaris API, optimized for notebook workflows and trading scripts. Documentation can be found at https://polaris.supply/docs

Install (uv)

uv sync --group dev

Useful commands:

uv run python
uv lock

Quickstart

from polaris_data import PolarisClient

with PolarisClient(api_key="polaris_key_your_key") as client:
    row_count = 0
    for row in client.replay(
        exchange="binance",
        asset="BTC-USDT",
        from_="2024-01-01T00:00:00Z",
        to="2024-01-01T01:00:00Z",
    ):
        row_count += 1

    print(f"Replayed {row_count} rows")

If api_key is omitted, the client reads POLARIS_API_KEY from the environment.

Supported input time types

Methods that take from_ and to accept:

  • ISO 8601 strings ("2024-01-01T00:00:00Z")
  • datetime.datetime
  • datetime.date
  • Unix epoch microseconds (int/float)

Methods

Open endpoints:

  • health()
  • catalog(exchange=None, asset=None)

Authenticated endpoints:

  • replay(exchange=..., asset=..., from_=..., to=..., standard=True) (iterator over /events or /raw)
  • trades(exchange=..., asset=..., from_=..., to=..., limit=1000) (collects all pages)
  • events(exchange=..., asset=..., from_=..., to=..., limit=1000) (prefers format=file, falls back to paginated JSON)
  • raw(exchange=..., asset=..., from_=..., to=..., limit=1000) (prefers format=file, falls back to paginated JSON)
  • ohlcv(exchange=..., asset=..., from_=..., to=..., interval=..., format=None)

For event/data endpoints, standard=True is the default. Pass standard=False when you explicitly need raw schema payloads.

Dataset replay (recommended)

For row-by-row iteration without managing file paths, use replay(...):

from polaris_data import PolarisClient

with PolarisClient(api_key="polaris_key_your_key") as client:
    for row in client.replay(
        exchange="binance",
        asset="BTC-USDT",
        from_="2024-01-01T00:00:00Z",
        to="2024-01-01T01:00:00Z",
    ):
        print(row)

replay(...) checks the local replay cache first, then requests bulk export (format=file) and streams the compressed .jsonl.zst response row-by-row. If file export is unavailable, it falls back to paginated JSON and still caches rows as NDJSON. Replay cache is enabled by default and stored under:

  • macOS: ~/Library/Caches/polaris/datasets/replay
  • Linux: ~/.cache/polaris/datasets/replay
  • Windows: %LOCALAPPDATA%\\polaris\\datasets\\replay

Set POLARIS_DATASET_DOWNLOAD_DIR to override the base directory globally. Use replay_cache_enabled=False to disable caching, or replay_cache_dir=... to set a custom path.

Error handling

from polaris_data import PolarisClient, RateLimitedError, UnauthorizedError

client = PolarisClient()

try:
    client.replay(
        exchange="binance",
        asset="BTC-USDT",
        from_="2024-01-01T00:00:00Z",
        to="2024-01-01T01:00:00Z",
    )
except UnauthorizedError:
    print("API key is required")
except RateLimitedError as err:
    print(f"Rate limited. Reset at: {err.reset_at}")

Tests

uv run pytest

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

polaris_data-0.4.1.tar.gz (32.0 kB view details)

Uploaded Source

Built Distribution

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

polaris_data-0.4.1-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file polaris_data-0.4.1.tar.gz.

File metadata

  • Download URL: polaris_data-0.4.1.tar.gz
  • Upload date:
  • Size: 32.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.22 {"installer":{"name":"uv","version":"0.9.22","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for polaris_data-0.4.1.tar.gz
Algorithm Hash digest
SHA256 55d129c40b15e54a76fc5e8066c7090a0781b87b802ebdf7455708a0a98ff3fb
MD5 a0a443d795b91e24929270768293869e
BLAKE2b-256 861fcd8430321fa2e04e41b9949869c4daef478003701c299eac628342dd01fb

See more details on using hashes here.

File details

Details for the file polaris_data-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: polaris_data-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 10.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.22 {"installer":{"name":"uv","version":"0.9.22","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for polaris_data-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cc6460e7f1790f0781a8043139c76e0aaddb4fdab2bebfcc5847d62dd3e38db8
MD5 011efe8a76a62a6488d982c29957bd25
BLAKE2b-256 e54b3765a4a9661117a5de4f1d34218db9d73f63b429e735fd81c281abf4fe55

See more details on using hashes here.

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