🐍 Investment statistics calculator.
This utility is available as a Python package on PyPI:
python3 -mpip install investats
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 withDST
.
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 theinvestats/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
).
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