fastest python trading bot
Project description
walrasquant
walrasquant is a high-performance Python framework for quantitative trading.
It is designed for low-latency execution, multi-exchange connectivity, and strategy development at scale.
Highlights
- Async-first architecture for real-time trading workflows
- Multi-exchange support (OKX, Binance, Bybit, Hyperliquid, Bitget)
- Built-in order and position lifecycle management
- Strategy framework with execution algorithms (including TWAP)
- Optional web API integration with FastAPI
- CLI and PM2 tooling for monitoring and operations
Installation
Requirements
- Python
>=3.11,<3.14 - Redis (recommended for monitoring and shared runtime state)
From PyPI
pip install walrasquant
From source
git clone https://github.com/walras-group/WalrasQuant.git
cd WalrasQuant
uv pip install -e .
Quick start
from decimal import Decimal
from walrasquant.constants import settings, ExchangeType, OrderSide, OrderType
from walrasquant.config import Config, BasicConfig, PublicConnectorConfig, PrivateConnectorConfig
from walrasquant.engine import Engine
from walrasquant.exchange.okx import OkxAccountType
from walrasquant.schema import BookL1, Order
from walrasquant.strategy import Strategy
OKX_API_KEY = settings.OKX.DEMO_1.api_key
OKX_SECRET = settings.OKX.DEMO_1.secret
OKX_PASSPHRASE = settings.OKX.DEMO_1.passphrase
class DemoStrategy(Strategy):
def __init__(self):
super().__init__()
self.subscribe_bookl1(symbols=["BTCUSDT-PERP.OKX"])
self.signal = True
def on_filled_order(self, order: Order):
print(order)
def on_bookl1(self, bookl1: BookL1):
if not self.signal:
return
self.create_order(
symbol="BTCUSDT-PERP.OKX",
side=OrderSide.BUY,
type=OrderType.MARKET,
amount=Decimal("0.1"),
)
self.create_order(
symbol="BTCUSDT-PERP.OKX",
side=OrderSide.SELL,
type=OrderType.MARKET,
amount=Decimal("0.1"),
)
self.signal = False
config = Config(
strategy_id="okx_demo_buy_sell",
user_id="user_test",
strategy=DemoStrategy(),
basic_config={
ExchangeType.OKX: BasicConfig(
api_key=OKX_API_KEY,
secret=OKX_SECRET,
passphrase=OKX_PASSPHRASE,
testnet=True,
)
},
public_conn_config={
ExchangeType.OKX: [PublicConnectorConfig(account_type=OkxAccountType.DEMO)]
},
private_conn_config={
ExchangeType.OKX: [PrivateConnectorConfig(account_type=OkxAccountType.DEMO)]
},
)
engine = Engine(config)
if __name__ == "__main__":
try:
engine.start()
finally:
engine.dispose()
CLI tools
After installation, the following commands are available:
wqfor PM2-based strategy process operations
Documentation
- Local docs source:
docs/
Contributing
Contributions are welcome. Please open an issue or submit a PR.
License
MIT License
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file walrasquant-0.4.9.tar.gz.
File metadata
- Download URL: walrasquant-0.4.9.tar.gz
- Upload date:
- Size: 232.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0ff342ba0500674c5697ccfda255594089ddf420fe780056b66ab6f9578d6fc1
|
|
| MD5 |
58205a3b60f18faf3ed56d063e8156cf
|
|
| BLAKE2b-256 |
c223697f6efca8c95e6b1af1905247a9388e2920877e220d05d8104b295b290b
|
File details
Details for the file walrasquant-0.4.9-py3-none-any.whl.
File metadata
- Download URL: walrasquant-0.4.9-py3-none-any.whl
- Upload date:
- Size: 277.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
78dace95b54f1268e1726f213c98c4d012ee43dd9639171fbc92e44921b66d1c
|
|
| MD5 |
5bfd5d5a7ca82fef952d98505e2e2499
|
|
| BLAKE2b-256 |
ed1d6cf58ca54b1ec33d30f56763c7d7ebc2f9309fe641120cf1a3ea21613c63
|