No project description provided
Project description
Hledger-lots
This package helps hledger users to add and manage transactions involving buying and selling commodities like stock, currency, etc.
Features
Add transaction
Instead of editing the journal file directly to add a commodity purchase or sale, answer some interactive prompts with the following benefits:
- Validation of allowed values for each field
- Fuzzy search completion using previous transaction data in the journal
- Select the answer between possible values or autocomplete when only one answer is allowed.
Automatic Lots
The most convoluted aspect of using hledger for investment is to manage lots because when selling a commodity, you need to use its cost, which is buried deep down in your journal, instead of the sale price, which is more easily available to add the correct profit/loss of the trade.
To calculate the cost, there are some methods you can apply and hledger doesn't provide tools to do it, so you are on your own. Hledger-lots calculate the cost without the need to alocate each purchase to a specific subaccount or tag. When you use hledger-lots sell
, it traverse the journal and arrive to the correct cost without additional information.
You can choose between two diferrent methods to calculate the cost of selling lots:
- FIFO: First In First Out
- AVERAGE COST: Average Cost of all previous purchase. It is as if selling a proportional part of each previous sale.
Automatic Price Download
One simple command to automatically download market price from Yahoo Finance for choosen commodities as explained here.
Reports
To get information about the commodities, there is more 2 commands:
command | description |
---|---|
view | Get the lots and indicators for a specific commodity |
list | Get the indicators for all commodities as a table |
The indicators provided by these command are explained here.
Documentation
Documentation with usage information can be found here
Setup
Requirements
Install
pip install --upgrade hledger-lots
Config
Instead of using command options, which is hard to remember and makes the command long, environment variables, which demands tweaking the .bashrc file or a configuration file, this app add configuration options directly in the journal using a custom directives specification explained here
You can still use LEDGER_FILE environment variable by adding
export LEDGER_FILE=your_data.journal
or prepend to the command:LEDGER_FILE=your_data.journal hledger-lots ...
Workflow
- Add a commodity purchase using the command buy or edit the journal as usual using "@" notation. Don't bother creating subaccounts or tags with unique lot name. See some examples here
- Download market price history from Yahoo Finance as price directive using the command prices
- View financial indicators for a specific commodity using view or a summary of all commodities using list.
- When you sell, use the command sell instead of adding the transactions manually. Hledger-lots will generate the correct transaction and append to the selected journal if you confirm the transaction is correct. See transaction tags with interesting indicators about the current trade
Indicators
Basic Indicators
- Commodity Name
- Total Quantity Purchased
- Total Amount Purchased
- Average Cost
Market Indicators
For commodities with price directives on a date after the last purchase, you will have also the following indicators:
- Last Market Price
- Market Amount: Quantitty Purchased * Last Market Price
- Market Profit: Market Amount - Amount Purchased
- Last Market Date
- XIRR
XIRR
The sale transaction gives you the calculated xirr as tag, which is the internal rate of return of an investment based on a specified series of irregularly spaced cash flows. This value is annual percentage rate following the 30/360US day count convention. It is a good metric to compare the investment return with a benchmark like the S&P or the T-Bill, for example.
Note the benchmark can use another day count convention, so this comparison may not be 100% precise. This app may in the future offer others day count convention for xirr calculation.
Checks
It is recommended to set the option check to true to ensure you past selling transaction has the correct cost according to the choosen cost method. See how to set it up here
Limitations
- No short-selling
- Each commodity can have only one base currency. For example, it is not possible to buy AAPL with USD and later with EUR.
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
Built Distribution
Hashes for hledger_lots-0.4.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | b07c3f4c8eacd56a2cea7b29c6f2d894e4079bd1d6ba2924cea1f82642855770 |
|
MD5 | 92841c269aa95384458fb4b918185827 |
|
BLAKE2b-256 | 4e3bf857ac109244bd7ca9bd62172a0e6d5ddbe9c36907acc1d59ffabd751a4f |