An advanced api client for python botters.
Project description
[BETA] pybotters
An advanced api client for python botters.
📌 Description
pybotters
は仮想通貨botter向けのPythonライブラリです。
複数取引所に対応した非同期I/OのAPIクライアントであり、bot開発により素晴らしいDXを提供します。
👩💻👨💻 In development
pybotters
は現在 ** BETAバージョン ** です。
一部機能は開発中です。
開発状況については こちら(Issues) を参照してください。
🚀 Features
- ✨ HTTP / WebSocket Client
- 複数取引所のプライベートAPIを自動認証
aiohttp
ライブラリを基盤とした非同期通信- WebSocketの自動再接続、自動ハートビート
- ✨ DataStore
- WebSocket用の自動データ保管クラス
- 参照渡しによる高速なデータ参照
- 取引所別データモデルの実装
- ✨ Developer Experience
asyncio
ライブラリを利用した非同期プログラミングtyping
モジュールによる型ヒントのサポート
🏦 Exchanges
Name | API auth | DataStore | API docs |
---|---|---|---|
Bybit | ✅ | ✅ | LINK |
Binance | ✅ | WIP | LINK |
FTX | ✅ | ✅ | LINK |
BTCMEX | ✅ | ✅ | LINK |
BitMEX | ✅ | WIP | LINK |
bitFlyer | ✅ | WIP | LINK |
GMO Coin | ✅ | WIP | LINK |
Liquid | ✅ | WIP | LINK |
bitbank | ✅ | WIP | LINK |
🐍 Requires
Python 3.7+
🛠 Installation
pip install pybotters
🔰 Usage
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 print handler)
ws = await client.ws_connect(
url='wss://stream.bybit.com/realtime',
send_json={'op': 'subscribe', 'args': ['trade.BTCUSD', 'order', 'position']},
hdlr_json=lambda msg, ws: print(msg),
)
await ws # this await is wait forever (for usage)
try:
asyncio.run(main())
except KeyboardInterrupt:
pass
Multiple exchanges
apis = {
'bybit': ['BYBIT_API_KEY', 'BYBIT_API_SECRET'],
'btcmex': ['BTCMEX_API_KEY', 'BTCMEX_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://www.btcmex.com/api/v1/order', data={'symbol': 'XBTUSD', ...: ...})
...
await client.post('https://dapi.binance.com/dapi/v1/order', data={'symbol': 'BTCUSD_PERP', ...: ...})
...
📖 Wiki
詳しい利用方法は👉Wikiページへ
🗽 License
MIT
💖 Author
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.2.2.tar.gz
(14.2 kB
view hashes)
Built Distribution
pybotters-0.2.2-py3-none-any.whl
(15.7 kB
view hashes)
Close
Hashes for pybotters-0.2.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 31f1f06030d8fd9d828dc0d9a94b102e62e794fe0571cd1ba9234732cc5c80d1 |
|
MD5 | 98cc9221aea2416db962a2fba12d2b8b |
|
BLAKE2b-256 | 06b37d04ff5d20ad386f4e9c233340e1c5b9c457a4c965b1615c9ce6ef7af222 |