Skip to main content

A Lightweight Python Package for Low-Latency and Cross-Exchange Trading.

Project description

KREX - A Lightweight Python Package for Low-Latency and Cross-Exchange Trading

A high-performance and lightweight Python library for interacting with cryptocurrency exchanges. KREX offers full synchronous and asynchronous support across major exchanges, designed for speed, modularity, and ease of use.

Python Version License: MIT PyPI version

📦 Installation

pip install krex

🚀 Quick Start

Synchronous Usage

import krex
import os

# Initialize client for any supported exchange
client = krex.binance(
    api_key="your_api_key",
    api_secret="your_api_secret"
)

# Get account balance
balance = client.get_account_balance()
print(balance)

# Get market data
klines = client.get_klines(symbol="BTCUSDT", interval="1h")
print(klines)

Asynchronous Usage

import asyncio
import krex.async_support as krex
import os

async def main():
    # Initialize async client
    client = await krex.binance(
        api_key="your_api_key",
        api_secret="your_api_secret"
    )

    try:
        # Get account balance
        balance = await client.get_account_balance()
        print(balance)

        # Get market data
        klines = await client.get_klines(symbol="BTCUSDT", interval="1h")
        print(klines)

    finally:
        await client.close()

if __name__ == "__main__":
    asyncio.run(main())

📚 Supported Exchanges

Exchange Sync Support Async Support
Binance
Bybit
OKX
BitMart
Gate.io
Hyperliquid
BitMEX
BingX Developing Developing
AscendEX Developing Developing
KuCoin Developing Developing

🔍 Key Features

  • 📘 Product Table Manager for unifying trading instruments in different exchanges
  • 🔁 Sync & Async API clients with identical interfaces
  • ⚡ Optimized for low-latency, high-frequency trading

What is Product Table Manager(ptm)?

Ptm is a utility that standardizes and unifies trading instrument metadata across different exchanges, making cross-exchange strategy development easier.

It is a table that contains the following columns:

Column Description
exchange The exchange name
product_symbol The symbol we use to identify the product, it will be the same in different exchanges. For example, BTC-USDT-SWAP is the same product in Binance and Bybit, which named BTCUSDT in Binance and BTC-USDT-SWAP in OKX.
exchange_symbol The symbol that the exchange will actually used
product_type The type we will use, e.g. spot, inverse, swap, futures
exchange_type The type the exchange will actually used, e.g. linear, INVERSE, perp... different exchanges have different types, pretty annoying...
base_symbol The base symbol, e.g. BTC
quote_symbol The quote symbol, e.g. USDT
price_precision The price precision, e.g. 0.000001
size_precision The size precision, e.g. 0.000001
min_size The minimum size, e.g. 0.000001
min_notional The minimum notional, e.g. 0.000001
multiplier The multiplier of the product, such symbol like 1000BONKUSDT in Bybit will need to be multiplied by 1000 to get the actual size, if you are trading across spot and swap, you will need this
size_per_contract The size per contract. Sometimes 1 contract is not the same as 1 unit in exchanges like OKX.

How to use Product Table Manager?

In most cases, we have handled the case, but if you have any specific use cases, you can use the ptm to get the information you want.

import krex

binance = krex.binance()

btcusdt_product_symbol = binance.ptm.get_product_symbol(
    exchange="binance",
    exchange_symbol="BTCUSDT",
    product_type="swap",
)

print(btcusdt_product_symbol)

🤝 Contributing

We welcome contributions! Please see our Contributing Guide for details.

Development Setup

# Clone the repository
git clone https://github.com/kairosresearchio/krex.git
cd krex

# We use `uv` to manage the project, you can install it with `pip install uv`
# Create a virtual environment
uv venv

# Install the dependencies
uv sync

Contributors

📄 License

This project is licensed under the MIT License.

🆘 Support

📜 Disclaimer

Cryptocurrency trading involves significant risk. This library is provided as-is without any warranty. Users are responsible for their own trading decisions and risk management.

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

krex-0.15.8.tar.gz (122.3 kB view details)

Uploaded Source

Built Distribution

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

krex-0.15.8-py3-none-any.whl (180.2 kB view details)

Uploaded Python 3

File details

Details for the file krex-0.15.8.tar.gz.

File metadata

  • Download URL: krex-0.15.8.tar.gz
  • Upload date:
  • Size: 122.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.13

File hashes

Hashes for krex-0.15.8.tar.gz
Algorithm Hash digest
SHA256 4d93b6cd1e7c464f0a9a3ea64c87c08a4cf8bdc3f7d1a3a55867447db4dc9077
MD5 909910768db7fcb0f0d6a0b6e5efbc20
BLAKE2b-256 79efb00873f154c063f621a3a216eb1b710811d4a04d6d6e0aa312c49f7c56bc

See more details on using hashes here.

File details

Details for the file krex-0.15.8-py3-none-any.whl.

File metadata

  • Download URL: krex-0.15.8-py3-none-any.whl
  • Upload date:
  • Size: 180.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.13

File hashes

Hashes for krex-0.15.8-py3-none-any.whl
Algorithm Hash digest
SHA256 269032570fa5a9fec95ed28776086d9e09f55e3eb576541a6420de879477b978
MD5 c0dcbc9c81e4ff98b7a5c7d0c33cf7f1
BLAKE2b-256 6899181e4f6113d75a09969628fa8d68aa0f0ffe597fc3b24d59c3111404d2d4

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