Skip to content

Library to split and share You Need A Budget (YNAB) transactions between two budgets

License

Notifications You must be signed in to change notification settings

dnbasta/ynab-split-budget

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ynab-split-budget

GitHub Release Github Release Monthly downloads

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.

"Buy Me A Coffee"

Preparations in YNAB

  1. Create a checking account for the cost sharing in both YNAB budgets.
  2. Create a personal access token for both budgets as described here

Install library from PyPI

pip install ynab-split-budget

Usage

1. Create a transaction

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.

2. Initialize library

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)

3. Split transactions

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()

4. Push new splits to partner split account

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)

Advanced Usage

Check Balances

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()

Delete Orphaned Complements

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()

Show Logs

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')

Run via bash

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

About

Library to split and share You Need A Budget (YNAB) transactions between two budgets

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages