Skip to content

dmotte/investats

Repository files navigation

investats

GitHub main workflow PyPI

🐍 Investment statistics calculator.

Installation

This utility is available as a Python package on PyPI:

python3 -mpip install investats

Usage

There are some files in the example directory of this repo that can be useful to demonstrate how this tool works, so let's change directory first:

cd example/

We need a Python virtual environment ("venv") with some packages to do the demonstration:

python3 -mvenv venv
venv/bin/python3 -mpip install -r requirements.txt

Note: we refer to the source asset of the investment with the generic ticker symbol SRC, and to the destination asset with DST.

Now we need some input data about some investments. You can generate dummy data using the investats_gen CLI entrypoint. Example commands:

python3 -minvestats_gen -d2021-01-01 -a.20 -c24 --fmt-rate='{:.4f}' data-AAA.yml
python3 -minvestats_gen -d2021-01-01 -a.30 -c24 --fmt-rate='{:.4f}' data-BBB.yml

Or you can scrape data from raw text files using the investats_scrape CLI entrypoint:

python3 -minvestats_scrape AAA transactions.txt --pfix-{inv-src=Amount,inv-dst=Shares,rate=Price}: -t0.15

Now that we have the data, we can compute the statistics about the investments:

for i in AAA BBB; do
    python3 -minvestats --fmt-{days,src}='{:.2f}' --fmt-{dst,yield}='{:.4f}' \
        --fmt-rate='{:.6f}' "data-$i.yml" "stats-$i.csv"
done

Note: each supported input and output entry field is described with a comment in the compute_stats function's code. You can search for the string # - entry_ in the investats/cli.py file to get an overview.

Then, we can aggregate the resulting data (related to multiple investments) into a single CSV file:

python3 -minvestats_aggr AAA stats-AAA.csv BBB stats-BBB.csv \
    --fmt-{days,src}='{:.2f}' --fmt-{dst,yield}='{:.4f}' --fmt-rate='{:.6f}' \
    > stats.csv

And finally display some nice plots using the plots.py script (which uses the Plotly Python library):

venv/bin/python3 plots.py -srga stats.csv

For more details on how to use these commands, you can also refer to their help message (--help).

Development

If you want to contribute to this project, you can install the package in editable mode:

python3 -mpip install -e . --user

This will just link the package to the original location, basically meaning any changes to the original package would reflect directly in your environment (source).

If you want to run the tests, you'll have to install the pytest package and then run:

python3 -mpytest test