Skip to main content

Simulator of a currency exchange.

Project description

Exchange Simulator

Build Status codecov Python Version

Simulator of a currency exchange. Key features:

  • Very minimalistic (300 lines in code), written in a functional style;
  • You can download a sample data from poloniex.com or provide your data in .csv files;
  • You can set an initial balance, use basic functions like buy, sell, go to the next time step;
  • More advanced features like a total capital calculation, and make portfolio, more about that at the link below;
  • Trading fees and minimum order amounts are supported.

Full API documentation is here: https://sergei-bondarenko.github.io/xchg/

Quick start

The package is available on pypi.org, so you can install it via pip:

pip install xchg

Then we need a market data. For tutorial purposes you can download it with this command which will be available after package installation:

download_candles

It will download 50 candles for ETC, ETH, LTC and XMR cryptocurrencies from poloniex.com exchange and put it in sample_data/ directory in the current path. Or you can download sample_data/ directory from this repository.

Later you can view these .csv files and use your own data in the same format. You can have a different number of currecies, and different set of columns. The only mandatory column is "close" price, as it will used for trading. Just ensure that you have the same time range for different currencies and have no gaps in data.

Prices in .csv files are expressed in a base currency, which will be called cash (if you are curious, in the sample data cash currency is BTC).

Now let's trade!

from xchg import Xchg

# Set an initial balance. Let's set that we have only cash currency at the
# start.
balance = {'cash': 100, 'ETC': 0, 'ETH': 0, 'LTC': 0, 'XMR': 0}

# Set a trading fee which will be paid for each buy or sell trade (in this
# example it's 1%). You can set 0 if you don't want any fee to be paid.
fee = 0.01

# Set a minimum order size expressed in a cash currency. You can not place
# orders less than that value. You can use also set 0 here if you don't
# want to limit a minimum order size.
min_order_size = 0.001

# Create an exchange.
ex = Xchg(fee, min_order_size, data_path='sample_data/', balance=balance)

# Let's buy some coins.
ex = ex.buy('ETC', 7500)
ex = ex.buy('LTC', 15000)

print(ex.balance)
# Output: {'cash': 2.2024749999999926, 'ETC': 7425.0, 'ETH': 0.0, 'LTC': 14850.0, 'XMR': 0.0}

# All done, now we want to wait for 30 time periods.
for _ in range(30):
  ex = ex.next_step()

# Now we want to sell.
ex = ex.sell('ETC', 7425)
ex = ex.sell('LTC', 14850)

print(ex.balance)
# Output: {'cash': 101.1232084225, 'ETC': 0.0, 'ETH': 0.0, 'LTC': 0.0, 'XMR': 0.0}

# We made more than 1 BTC profit, yay!

For developers

Install testing modules:

pip install pytest pytest-flake8 pytest-cov

Use the following command to run tests locally:

pytest --flake8 --cov=xchg --cov-report term-missing -vvv

And do not forget to increase a version in xchg/__init__.py before commiting.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

xchg-6.0.1.tar.gz (9.1 kB view details)

Uploaded Source

Built Distribution

xchg-6.0.1-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file xchg-6.0.1.tar.gz.

File metadata

  • Download URL: xchg-6.0.1.tar.gz
  • Upload date:
  • Size: 9.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for xchg-6.0.1.tar.gz
Algorithm Hash digest
SHA256 6a7784fea11212362330c235f2438d443f06f3451bffd995c8a687097ec3ab72
MD5 8ded80357b3027107b136c859e4b3cbb
BLAKE2b-256 7fb154197b407ea47cd77744f4379c8ff5740d5b4d75067faf798b284b4a65bb

See more details on using hashes here.

File details

Details for the file xchg-6.0.1-py3-none-any.whl.

File metadata

  • Download URL: xchg-6.0.1-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for xchg-6.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ad9950b951019b09ef0205488abf60c254c38977af16cdc93b32dc64444c739a
MD5 7f54333a644b337e2a7faf2d6d7ee196
BLAKE2b-256 677305e18ed1b1c84de32457f0e4d049050c5d8fbc30164f71b2367dca231635

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page