API Reference

This section documents the mt5cli public Python API and CLI modules.

Start with the Public API Contract for the stable downstream SDK surface, CLI boundary, internal modules, and out-of-scope strategy responsibilities.

Public API layers

Module Purpose
Public API Contract Stable downstream SDK exports, CLI boundary, and out-of-scope items
Client MT5Client session abstraction for data access and order primitives
Schemas Canonical DataFrame contracts and normalization helpers
Storage CSV/JSON/Parquet/SQLite export and history collection helpers
Converters Symbol, timeframe, timezone, and date-range utilities
Exceptions Stable mt5cli exception types and MT5 error normalization
SDK Module-level fetch helpers, multi-account collectors, incremental history
Trading Trading-capable sessions and operational helpers
History Collection (SQLite) SQLite schema, incremental writes, dedup, and rate views
CLI Typer commands that delegate to the Python API
Utils Parsing helpers and Click parameter types

Architecture overview

flowchart TD
    App["Downstream application"] --> Client["MT5Client"]
    CLI["mt5cli CLI"] --> Client
    Client --> SDK["sdk / pdmt5"]
    Client --> Schemas["schemas"]
    Storage["storage"] --> History["history SQLite"]
    Storage --> Utils["utils export"]
    SDK --> PDMT5["pdmt5.Mt5DataClient"]

Downstream packages should depend on the package root exports documented in the Public API Contract (MT5Client, DataKind, normalize_dataframe, collect_history, load_rate_data, resolve_rate_view_name, etc.) rather than private modules.

MT5Client.order_send() is a live execution primitive that can place real trades. mt5cli exposes minimal execution helpers only; strategy logic, signals, backtests, and optimization remain out of scope and must be implemented downstream with explicit execution gating.

Quick start

from mt5cli import MT5Client, build_config, mt5_session

with mt5_session(build_config(login=12345)) as client:
    rates = client.copy_rates_range("EURUSD", "H1", "2024-01-01", "2024-02-01")
    positions = client.positions()
mt5cli -o account.csv account-info
mt5cli -o rates.parquet rates-range --symbol EURUSD --timeframe H1 \
  --date-from 2024-01-01 --date-to 2024-02-01

See individual module pages for detailed usage examples.