An advanced API client for python botters.
Project description
[Preview] pybotters
An advanced API client for python botters.
📌 Description
pybotters
は 仮想通貨 botter 向けの Python ライブラリです。
複数取引所に対応した非同期 I/O の API クライアントであり、bot 開発により素晴らしい DX を提供します。
🚧 In development
pybotters
は現在 ** Previewバージョン ** です。
一部機能は開発中です。
開発状況については こちら(Issues) を参照してください。
🚀 Features
- ✨ HTTP / WebSocket Client
- 複数取引所のプライベート API を自動認証
aiohttp
ライブラリを基盤とした非同期通信- WebSocket の自動再接続、自動ハートビート
- ✨ DataStore
- WebSocket 用のデータ保管クラス
- ピュア Python データモデルによる高速なデータ参照
- 取引所別モデルの実装
- ✨ Developer Experience
asyncio
ライブラリを利用した非同期プログラミング- 型ヒントのサポート
🏦 Exchanges
Name | API auth | DataStore | API docs |
---|---|---|---|
Bybit | ✅ | ✅ (Futures v2) | Official v5 / Futures v2 |
Binance | ✅ | ✅ | Official |
OKX | ✅ | ✅ | Official |
Phemex | ✅ | ✅ | Official |
Bitget | ✅ | ✅ | Official |
MEXC | ✅ | WIP | Official / v3 |
KuCoin | ✅ | ✅ | Official |
BitMEX | ✅ | ✅ | Official |
bitFlyer | ✅ | ✅ | Official |
GMO Coin | ✅ | ✅ | Official |
bitbank | ✅ | ✅ | Official |
Coincheck | ✅ | ✅ | Official |
🐍 Requires
Python 3.7+
🔧 Installation
pip install pybotters
🌏 Quickstart
Single exchange
import asyncio
import pybotters
apis = {
"bybit": ["BYBIT_API_KEY", "BYBIT_API_SECRET"],
}
async def main():
async with pybotters.Client(apis=apis, base_url="https://api.bybit.com") as client:
# REST API
resp = await client.get("/v2/private/position/list", params={"symbol": "BTCUSD"})
data = await resp.json()
print(data)
# WebSocket API (with defautl print handler)
ws = await client.ws_connect(
url="wss://stream.bybit.com/realtime",
send_json={"op": "subscribe", "args": ["trade.BTCUSD", "order", "position"]},
)
await ws # Ctrl+C to break
try:
asyncio.run(main())
except KeyboardInterrupt:
pass
Multiple exchanges
apis = {
"bybit": ["BYBIT_API_KEY", "BYBIT_API_SECRET"],
"binance": ["BINANCE_API_KEY", "BINANCE_API_SECRET"],
}
async def main():
async with pybotters.Client(apis=apis) as client:
await client.post("https://api.bybit.com/v2/private/order/create", data={"symbol": "BTCUSD", ...: ...})
...
await client.post("https://dapi.binance.com/dapi/v1/order", data={"symbol": "BTCUSD_PERP", ...: ...})
...
📖 Wiki
詳しい利用方法は 👉 GitHub Wiki
現在こちらに移行中です 👉 Read the Docs
🗽 License
MIT
💖 Author
Twitter:
Discord:
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
pybotters-0.16.0.tar.gz
(44.2 kB
view hashes)
Built Distribution
pybotters-0.16.0-py3-none-any.whl
(57.3 kB
view hashes)
Close
Hashes for pybotters-0.16.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0fdc8eb810d2ba593b6ae2538d989527ba6ef08c69a13a30b0c4266803c54775 |
|
MD5 | 537ba9a28a0de8c027f3c65db7afa244 |
|
BLAKE2b-256 | d213423a6714870c9285d324587a0fb1953bb20b5591bbc20861fa0675486451 |