An advanced api client for python botters.
pybottersは仮想通貨botter向けのPythonライブラリです。
複数取引所に対応した非同期I/OのAPIクライアントであり、bot開発により素晴らしいDXを提供します。
pybotters は現在 ** Previewバージョン ** です。
一部機能は開発中です。
開発状況については こちら(Issues) を参照してください。
- ✨ HTTP / WebSocket Client
- 複数取引所のプライベートAPIを自動認証
aiohttpライブラリを基盤とした非同期通信- WebSocketの自動再接続、自動ハートビート
- ✨ DataStore
- WebSocket用の自動データ保管クラス
- 参照渡しによる高速なデータ参照
- 取引所別データモデルの実装
- ✨ Developer Experience
asyncioライブラリを利用した非同期プログラミング- 型ヒントのサポート
| Name | API auth | DataStore | API docs |
|---|---|---|---|
| Bybit | ✅ | ✅ | Official |
| 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 |
Python 3.7+
pip install pybottersimport 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:
passapis = {
'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ページへ
現在こちらにに移行中です👉Read the Docs
MIT
Twitter: https://twitter.com/MtkN1XBt