This project is in progress, eventually it will be able to automatically manage several strategies, signal calculation, order execution, allow history performance, etc.
Initially Trading_Bot
will be used with the Kraken crypto-currency exchange platform, but in the long term this project may be extended to other trading platforms (e.g. Bitfinex, Bitmex or some more classical trading platforms as Interactive-Brokers).
-
System:
- Unix OS (Linux or MacOS)
-
Python version:
- 3.7
- 3.8
-
Python package:
- blessed
- fynance
- numpy
- pandas
- requests
At the root of a folder, clone the repository and install it with pip
:
$ git clone https://github.com/ArthurBernard/Trading_Bot.git
$ cd Trading_Bot
$ pip install -e trading_bot
At the root of Trading_Bot
:
Make a folder ./strategies/YOUR_STRATEGY_NAME
with 3 scripts to configurate the strategy: __init__.py
an empty file, configuration.yaml
and strategy.py
. See examples in the following directory ./strategies/example/
and ./strategies/another_example/
.
$ mkdir ./strategies/YOUR_STRATEGY_NAME
$ touch ./strategies/YOUR_STRATEGY_NAME/__init__.py
$ touch./strategies/YOUR_STRATEGY_NAME/configuration.yaml
$ touch ./strategies/YOUR_STRATEGY_NAME/strategy.py
TODO : tuto how write configuration.yaml
and strategy.py
.
Set ./general_config.yaml
file (or let it as default) with:
log_file
: the path of your log file.strategy
: the path where you save your custom strategy functions.address
: address of your server and port (can be local or remote).authkey
: password of your server.auto
: if true starts automatically the order manager and performance manager client, otherwise you must to run it mannually.
And run the trading bot:
$ python ./trading_bot/bot_manager.py > /dev/null 2>&1 &
If you have to choose to run mannually the order manager and trading performance manager clients:
$ python ./trading_bot/orders_manager.py &
$ python ./trading_bot/performance.py &
$ python ./trading_bot/cli.py
With the CLI you can start or stop one or several strategy bots, display KPI of the running strategy bots and stop the trading bot.
The following command lines are available:
q
: quite the command line interface.stop
: stop the trading bot server and all the client strategies.stop [STRATEGY_NAME]
: stop the strategy bot managerSTRATEGY_NAME
.start [STRATEGY_NAME]
: start the strategy bot managerSTRATEGY_NAME
.<ENTER>
: display the performance table of running strategies.
TODO: append more command lines (e.g dispaly plot of performance, force to execute a pending order (i.e if an order wasn't executed due to a bug), etc.)
You can see the logs of trading bot in the files debug.log
and error.log
.
Documentation is available at [comming soon].
Do not risk money which you are afraid to lose. Use the trading bot at your own risk, the authors assume no responsibility for your trading results. Read the source code and make sure there are not undesirable behaviors.
- General:
- Make documentation and clean objects;
- Improve Quick-Start;
- Improve CLI/make GUI.
bot_manager.py
:- Start automatically several
StrategyManager
clients on several process;
- Start automatically several
_order.py
:- Use WebSockets instead of REST API.
strategy_manager.py
:- Choose invested value in quote or base currency.