This library enables cost sharing across two YNAB budgets. It requires two dedicated accounts in each budget to which each budget owner can transfer amounts from their own budget. Each transfer is considered as its opposite in the other account.
- Create a checking account for the cost sharing in both YNAB budgets.
- Create a personal access token for both budgets as described here
pip install ynab-split-budget
Create a transaction in the budget and add a specific flag color for the splits. The
transaction needs to be cleared in order to be considered by this library. By default, the transaction will be split
in half, but you can specify a different split by adding @x%
for percentage or @x
for specific amount in the memo
of the transaction. The amount you specify in this split will be transferred to your sharing account. You can also
create a plain transfer to the shared account which will be completely allocated to the partner account.
Initialize the library by creating two User
instances and pass them as user and partner to the constructor of the
main class. For the flag_color set the value used marking the transaction earlier. Possible color values are red
,
orange
, yellow
, green
, blue
and purple
. The id of the budget and of the account can be found going to
https://app.ynab.com/ and opening the target account by clicking on the name on the left hand side menu. The URL does
now contain both IDs https://app.ynab.com/<budget_id>/accounts/<account_id>
.
The User
object can be optionally initialized from a YAML file using the from_yaml()
classmethod.
from ynabsplitbudget import YnabSplitBudget, User
user = User(name='<name>', token='<token>', budget_id='<budget_id>',
account_id='<account_id', flag_color='<flag_color>')
partner = User(name='<name>', token='<token>', budget_id='<budget_id>',
account_id='<account_id', flag_color='<flag_color>')
split_budget = YnabSplitBudget(user=user, partner=partner)
Call the split()
method of the instance. It will split flagged transactions in the budget into a subtransaction with
the original category and a transfer to the split account. By default, the transfer transactions will show up as
uncleared in the split account.
split_budget.split()
Calling the push()
function will insert new transactions from user split account into split account of partner to keep
both accounts in sync. By default, the function will only consider cleared transactions. This is in general a safer
option as it forces users to manually check and clear transactions in the split account. However, it makes running the
whole functionality automatically cumbersome, hence the function takes an optional include_uncleared
parameter which,
if set to True
, makes it also consider uncleared transactions.
Additionally by default, the function will compare and insert transactions of the last 30 days. Optionally it
takes a since
parameter in the form of datetime.date
to set a timeframe different from 30 days.
split_budget.push()
# or optionally with considering uncleared transactions as well
split_budget.push(include_uncleared=True)
The raise_on_balances_off()
function compares the cleared balances in both split accounts. If they don't match it
will raise a BalancesDontMatch
error which includes the values of the balances.
split_budget.raise_on_balances_off()
The delete_orphans()
function deletes orphaned transactions in the partner split account, which don't have a
corresponding transaction in the user split account any more. It does return a list with the deleted transactions.
By default, the function compares transactions of the last 30 days. Optionally it takes a since
parameter in the
form of datetime.date
to set a timeframe different from 30 days.
split_budget.delete_orphans()
The library logs information about the result of the methods at the 'INFO' level. The logs can be made visible by
importing the logging module and set it to the level INFO
. The logger itself can also be accessed via the logger
attribute of the instance.
import logging
logging.basicConfig(level='INFO')
You can run this library also from bash with the following basic structure
$ python -m ynabsplitbudget -u <path/user.yaml> -p <path/partner.yaml> --split
For a complete list of available bash options please use
$ python -m ynabsplitbudget -h | -- help