HOWTO: Downgrade from nYNAB to YNAB4

Related tags

Miscellaneousynab
Overview

HOWTO: Downgrade from nYNAB to YNAB4

This page explains how to move from nYNAB to YNAB4 while retaining as much information as possible. See Appendix 1 for reasons and how to get YNAB4 running.

You will export your current nYNAB budget, then perform some scripted steps on the exported data, and then gradually import it into a new YNAB4 budget. The scripted steps assume that you know how to use Python. (If anybody wants to improve this guide with setup instructions, PRs are welcome!)

Sadly, there is not much scripted at the moment – you will spend time on manual tasks. But at least, this page supplies a guide for handling this stuff a bit better.

Caveats

Don't expect an automated and smooth process – this repo is more of a guide with two helper scripts. If things go wrong, you can always delete your YNAB4 data and start again. Since we're starting with a new YNAB4 budget, nothing will be lost.

Split transactions won't be imported as splits, but rather as individual transactions. The memo field will say "Split 1/n" though, so you'll still see which transactions belonged together.

I also don't use many YNAB features including loans and separate credit card accounts, so the import might not work correctly for them. Please open PRs with updates if you find required changes, or comment on the main issue if it worked for you with a specific scenario, so others will know what works and what doesn't!

Preliminaries

In nYNAB: Check if any of your category names contain a : or a `, as those are not valid characters in YNAB 4. Change these category names now. Also unhide all of your previously hidden categories, as the import will otherwise not work for them, and you'll have to re-categorise them manually. (Not a big deal because they will be easy to filter for, but annoying regardless).

In nYNAB: Export your nYNAB budget by clicking on the budget name in the upper right hand corner → Export Budget. Download the resulting zip file (once your browser has stopped freezing if your budget is a bit older), and extract the zip archive. It contains two files: Budgetname as of date - Budget.csv and Budgetname as of date - Register.csv. I'll refer to these as Budget.csv and Register.csv from here on out.

In YNAB4: Install YNAB 4 (see Appendix 1) and set up a new budget. Set the directory to some place that works well for you (some location you will backup or sync, for example) in the File → Preferences dialog. Go to the directory you selected: You will find a directory called My Budget~number.ynab4. Inside, there is a data1~number directory, and inside that, there is a directory that is just one long UID, looking like 98C499B4-4B29-6CC5-3B7A-F0247E9E2551. Open this directory – it will contain a budgetSettings.ybsettings file and a Budget.yfull file. I will call this directory "YNAB4 data directory" from here on out.

Step 1: Creating accounts

As a first step, create all your accounts in YNAB 4. Please make sure they are spelt exactly like in nYNAB. Take care to also create closed accounts!

(It's probably not worth to automate this step, especially since the nYNAB export does not contain account information like the account type, so even if we write an importer, we'd still have to manually correct the account type, and people usually have a limited amount of accounts.)

Now's a good time to make a backup of your YNAB4 data directory, because if something down the line fails, you won't want to go through this a second time.

Step 2: Creating categories

While accounts are limited in number, categories can be a lot, so I wrote a tiny importer. Make sure to close YNAB 4 before running it – it overrides the data file on closing!

python create_categories.py path/to/ynab4_data_directory path/to/Budget.csv

Step 3: Splitting the payment export file

Now run the second split to take apart the transaction export – YNAB 4 can only import on a per-account basis.

python split_export.py path/to/nynab_data_directory/Register.csv

This will place one CSV file for each account in your working directory, and will replace some terms to make successful imports more likely.

Step 4: Importing files

You'll want to import every file next, each under the appropriate account. Make sure to select Year/Month/Date as time format, as well as "Include transactions before account start date".

Next, approve all transactions and recategorise if any did not receive a matching category on import. This shouldn't happen, but probably will in some edge cases. If YNAB can't find a category, it should put the category in the memo field, so that in most cases, you can search for that field, bulk-select and handle the transactions fairly quickly.

And now the tedious part: When you transferred money from account A to B, this transaction shows up in the account A export and the account B export – but since YNAB 4 does not know that we'll provide both imports, it also auto generates the matching transfer transaction, so every transfer exists twice. You have to go through the list of all transactions, filter for Transfer, and delete every other one :/

To do this, first filter by "Is: Cleared, Transfer". Then, the easiest workflow is to mark the first transaction, then hold Ctrl, and keep pressing down, down, space. Delete either all the inflows or outflows – it doesn't matter, as their counterparts will also disappear.

For context: I used nYNAB for just over five years, and I had to mark around 150 transactions. Not great, but not terrible, either.

Step 5: Cleanup

Now, chances are, some accounts won't have the correct balance. I'm not quite sure what's going on, to be quite honest. Out of my 7 accounts, 2 were off (one by a bit, one by a bit more), the other five came out correct. Things to check:

  • An imported starting balance can be marked incorrectly, either change the flow direction or delete it.
  • Mark a suspect time period (first and last month / year / quarter) in both nYNAB and YNAB 4 and compare the totals.

Now, once all the account totals are correct: you can be done. Just copy your current category bucket total into your YNAB 4, and you're ready to go. Congratulations!

Step 6: Budget import (optional)

Unless you want your budget history to be imported, too – do you want to know how much money you set aside for vacation in 2017? … If so: quit YNAB 4 and make a backup of the directory! Seriously: Your current state is very good and you really don't want to repeat the work you just did if the budget import screws up somehow.

Then run:

python import_budgets.py path/to/ynab4_data_directory path/to/Budget.csv

All your budget data should get imported. Please let me know if this doesn't work – I'm assuming currencies with a single symbol and two decimal places, for example, because I'm lazy like that. You might also try entering a random number into your first month (e.g. April 2016) in YNAB 4 if the import fails – this will cause YNAB to create all the monthly buckets, so that the importer only has to add the correct numbers.

When you open YNAB 4, the total budgeted numbers per category should be correct – if you use future budgeting a lot, it might look off at first, because you'll have large visible numbers as "not budgeted". These numbers are correct though, and should line up with what you see in the breakdown when you click the month's total in nYNAB.

Appendix 1: YNAB 4

YNAB 4 is a desktop application that was the predecessor of the web version, commonly called nYNAB (or just YNAB). YNAB 4 did not have a subscription model, but can't be purchased anymore. If you bought it back in the day, you can still use your activation key. You might also have bought it on Steam, where it will still be activated for you.

If you didn't purchase YNAB 4, you can still download it and run through the 1-month trial. There are trivial ways to extend or repeat or circumvent the trial duration, however, as those are naturally against the TOS of YNAB, I will not document or endorse them here.

Owner
Tobias Kunze
I build things, like @pretalx or @venueless. I run events, like @metarheinmain or @c3cashdesk. I stream my keyboard bashing at https://twitch.tv/rixxian
Tobias Kunze
A hackerank problems, solution repository

This is a repository for all hackerank challenges kindly note this is for learning purposes and if you wish to contribute, dont hesitate all submision

Tyler Mwalo Kenneth's 1 Dec 20, 2021
Simple web application, which has a single endpoint, dedicated to annotation parsing and convertion.

Simple web application, which has a single endpoint, dedicated to annotation parsing and conversion.

Pavel Paranin 1 Nov 01, 2021
A functional standard library for Python.

Toolz A set of utility functions for iterators, functions, and dictionaries. See the PyToolz documentation at https://toolz.readthedocs.io LICENSE New

4.1k Jan 04, 2023
Coderslab Workshop Projects

Workshop Coderslab workshop projects that include: Guessing Game Lotto simulator Guessing Game vol.2 Guessing Game vol.3 Dice 2001 Game Technologies P

Szymon Połczyński 1 Nov 06, 2021
The program converts Swiss notes into American notes

Informatik-Programmieren Einleitung: Das Programm rechnet Schweizer Noten in das Amerikanische Noten um. Der Benutzer kann seine Note eingeben und der

2 Dec 16, 2021
A python library for writing parser-based interactive fiction.

About IntFicPy A python library for writing parser-based interactive fiction. Currently in early development. IntFicPy Docs Parser-based interactive f

Rita Lester 31 Nov 23, 2022
A slapdash script to solve Wordle or Absurdle automatically

A slapdash script to solve Wordle or Absurdle automatically

Michael Anthony 1 Jan 19, 2022
Context-free grammar to Sublime-syntax file

Generate a sublime-syntax file from a non-left-recursive, follow-determined, context-free grammar

Haggai Nuchi 8 Nov 17, 2022
Curses frontend for Canto daemon

Canto Curses The curses (text) client for canto-daemon. Canto-daemon is required to work and is found at: http://github.com/themoken/canto-next Requir

Jack Miller 86 Dec 28, 2022
Developer guide for Hivecoin project

Hivecoin-developer Developer guide for Hivecoin project. Install Content are writen in reStructuredText (RST) and rendered with Sphinx. Much of the co

tweetyf 1 Nov 22, 2021
Get a list of content on your Netflix My List that is expiring in the next month or two.

Netflix My List Expiring Movies Annoyed at Netflix for taking away your movies? Now you don't have to be! Installation instructions Install selenium C

24 Aug 06, 2022
Python plugin for Krita that assists with making python plugins for Krita

Krita-PythonPluginDeveloperTools Python plugin for Krita that assists with making python plugins for Krita Introducing Python Plugin developer Tools!

18 Dec 01, 2022
Sathal's Python Projects Repository

Sathal's Python Projects Repository Purpose and Motivation I come from a mainly C Programming Language background and have previous classroom experien

Sam 1 Oct 20, 2021
Just a little benchmark for scrapper PC's

PopMark Just a little benchmark for scrapper PC's This benchmark is for old computer that dont support other benchmark because of support. Like lack o

Garry 1 Nov 24, 2021
Programa principal de la Silla C.D.P.

Silla CDP Página Web Contáctenos Lista de contenidos: Información del proyecto. Licencias. Contacto. Información del proyecto Silla CDP, o Silla Corre

Silla Control de Postura 1 Dec 02, 2021
A tool that bootstraps your dotfiles ⚡️

Dotbot Dotbot makes installing your dotfiles as easy as git clone $url && cd dotfiles && ./install, even on a freshly installed system! Rationale Gett

Anish Athalye 5.9k Jan 07, 2023
Web站点选优工具 - 优化GitHub的打开速度、高效Clone

QWebSiteOptimizer - Web站点速度选优工具 在访问GitHub等网站时,DNS解析到的IP地址可能并不是最快,过慢的节点会严重影响我们的访问情况,故制作出这样的工具来进一步优化网络质量。 由于该方案并非为VPN等方式进行的速度优化,以下几点需要您注意: 后续访问对应网站时仍可能需

QPT Family 15 May 01, 2022
A comprensive software collection for nmea manipulation

nmeatoolkit A comprensive software collection for nmea manipulation; it includes a library and a collections of command line tools. Library pipes: con

Davide Gessa 1 Sep 14, 2022
An evolutionary multi-agent platform based on mesa and NEAT

An evolutionary multi-agent platform based on mesa and NEAT

Valerio1988 6 Dec 04, 2022
:art: Diagram as Code for prototyping cloud system architectures

Diagrams Diagram as Code. Diagrams lets you draw the cloud system architecture in Python code. It was born for prototyping a new system architecture d

MinJae Kwon 27.5k Jan 04, 2023