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()
  • exchanges()
  • assets(exchange=...)
  • timerange(exchange=..., asset=...)
  • dataset_size(exchange=..., asset=..., from_=..., to=...)
  • catalog()
  • dataset_preview(..., standard=True)
  • ohlcv_preview(..., interval, limit=None, format=None)

Authenticated endpoints:

  • dataset_download_url(exchange=..., asset=..., from_=..., to=..., standard=True)
  • replay(exchange=..., asset=..., from_=..., to=..., standard=True) (stream rows from dataset download URL)
  • download_dataset(exchange=..., asset=..., from_=..., to=..., standard=True, destination=None, filename=None, overwrite=False, decompress=True, keep_compressed=False)
  • trades_page(exchange=..., asset=..., from_=..., to=..., limit=1000, cursor=None)
  • iter_trades(exchange=..., asset=..., from_=..., to=..., limit=1000)
  • collect_all_trades(exchange=..., asset=..., from_=..., to=..., limit=1000)
  • stream_events(exchange=..., asset=..., from_=..., to=..., standard=True)
  • collect_events(exchange=..., asset=..., from_=..., to=..., standard=True)
  • iter_ohlcv(exchange=..., asset=..., from_=..., to=..., interval=...)
  • 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 fetches and caches the dataset if needed. Replay cache is enabled by default and initialized when the client is created.

Optional: persist dataset files

For safety, file downloads are disabled by default. Enable them explicitly when you want to save files locally:

from polaris_data import PolarisClient

with PolarisClient(
    api_key="polaris_key_your_key",
    allow_dataset_downloads=True,
) as client:
    file_path = client.download_dataset(
        exchange="binance",
        asset="BTC-USDT",
        from_="2024-01-01T00:00:00Z",
        to="2024-01-01T01:00:00Z",
    )
    print(file_path)

download_dataset(...) decompresses .zst files by default and returns the decompressed file path (for example .jsonl). Set decompress=False to keep the original .zst, or keep_compressed=True to keep both files.

Default download directories:

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

You can override this with dataset_download_dir=... on the client or destination=... on a single download_dataset(...) call. Set POLARIS_DATASET_DOWNLOAD_DIR to override the default directory globally. Replay cache defaults to a replay/ subdirectory under dataset_download_dir. Use replay_cache_enabled=False to disable replay caching, or replay_cache_dir=... to move it.

Error handling

from polaris_data import PolarisClient, RateLimitedError, UnauthorizedError

client = PolarisClient()

try:
    client.collect_events(
        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.2.0.tar.gz (34.1 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.2.0-py3-none-any.whl (12.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: polaris_data-0.2.0.tar.gz
  • Upload date:
  • Size: 34.1 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.2.0.tar.gz
Algorithm Hash digest
SHA256 ec1d11111c3885efad5b228bc0397337e42a80ab39a5a9f0dc1218b4bcb98749
MD5 efac42f5dcfa0e7fac5b73bd7d54caae
BLAKE2b-256 7b85e47b4e04ec92418322f9a125b19658c72e3f2a45ef0fa8d922b87f1ef52a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: polaris_data-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 12.5 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d9c0a8cdd1cfb69b60f16b0de4e640dbf1cf8951df2e6cf7f97b699192c766a2
MD5 d3ee298ea9dfc7632a40a0413ed8ae10
BLAKE2b-256 d2eda96a7dba427a7eb939cb45ce6f3345add91decd8600fa57576f1a620c577

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