moneyGuru is loosely based on double-entry accounting. The core of the system is the transaction which represents a movement of money from some account(s) to some other account(s) at a particular date. A transaction consists in a zero-sum set of 2 or more entries to 2 or more accounts. Any account, whether it’s an asset or an income, can send money to any other account. This comes handy when it comes to cash management. There’s not much else to describe for the basics of the system itself. Things get a little more complex when multiple currencies are involved, but the details about that are described on the currencies page.
moneyGuru is based around different views (the main ones are explained below) through which you
manage your moneyGuru document. These views are managed through tabs. Tabs behave like any other
tab-enabled app. You open a new tab with ⌘T, you close it with ⌘W, you can cycle through
tabs with ⌘⇧←→. Whenever you open an account with the
arrow, a
new tab is opened (or if it was already opened, it’s selected) for that account.
The currently selected date range affects the whole application. Everything you see in the views is for the current date range. For example, if “Jan 2010 - Dec 2010” is selected, everything that you see in all the views is data from 2010/01/01 to 2010/12/31. The range is controlled by this little widget:

There are 7 types of date ranges:
For “navigable” date ranges (Month, Quarter, Year), you can use the arrows to select the previous or the next date range (on the keyboard, it’s ⌘⌥[ and ⌘⌥]). There are also shortcuts to select date range types (⌘⌥1-7). You can also press ⌘⌥T to return to today’s date range.
When selecting custom date ranges, you also have the option to have moneyGuru put that date range into one of the 3 available slots. When you do this, a new date range will appear in the menu and will be quickly re-callable.
All information in moneyGuru is displayed according to the currently selected date range. Things get interesting when the date range ends at a future date. If you have scheduled transactions or budget set up, the numbers you will see and the chart you will look at will include them. In the graphs, there is a sharp distinction between the past and the future. The past is displayed in green, and the future is displayed in gray, a thin red line separating both. So when you look at the grey part of graphs, you are looking at stuff that has not happened yet. Your net worth in your balance sheet will count the yet-to-happen scheduled transactions as well as budgets. Sometimes, you just want to know about your current financial situation. This is what the “Year to date” (⌘⌥4) date range is for.
Many tab views have graphs and charts, and all of them have table columns. You can control the visibililty of those elements through the buttons at the bottom of the main window. If you click on the Columns visibility button, you’ll get a list of all optional columns for the currently active tab view. Through that menu you can toggle these columns’ visibility.

The Net Worth and Profit & Loss views are where you do account management and get statistics about your financial situation. They both have a similar layout and behave the same way.
Sheet: At the top left, there is the “sheet”, listing accounts, gives totals account groups. Totals are always given in your native currency. You can also add, change and remove accounts from this sheets.
Show Account: Next to each account, there is a little
. You can click on it to show this account in the Account view. You can also select it and press ⌘→.
Account Exclusion: You can also “exclude” accounts by clicking on the little
icon, or by pressing ⌘⇧X. Excluded accounts are not counted in the sheet’s totals or in the charts.
Pie Chart: At the right of the sheet of each view are two pie charts showing the weight of every account for each type. If you have account groups, you can collapse one of these groups in the sheet to have the account values grouped in the pie chart. For example, if you have a “Automobile” group with a few related accounts under it, you can collapse the group in the sheet to have “Automobile” as one slice (rather than having one slice for Gas, one slice for Insurance, etc..).
Graph: The graph at the bottom of the view shows the progression of the primary view statistic (net worth or profit) over time.
Columns: The sheets each have a different set of columns.
Balance Sheet:
- Account #: An optional account number reference tied to the account. See the editing page for more info.
- Start: The balance of the account at the beginning of the date range. It includes scheduled transactions, but not budgets.
- End: The balance of the account at the end of the date range.
- Change: The difference between Start and End.
- Change %: The difference in percentage between Start and End
- Budgeted: The amount of budget (for which this account is a target) left to allocate in this current date range. This means that, if your budgets correctly reflect reality, End + Budgeted should be your actual balance at the end of the date range.
Profit & Loss:
- Account #: Same as in the Balance sheet.
- Current: The cash flow of the account for the current date range.
- Last: The cash flow of the account for the last date range. For example, if in a month range, the Last column shows the cash flow for the month prior to the current one. Year-to-date is a special case and under it, the Last column displays the last year’s cash flow.
- Change and Change %: Same as in the balance sheet.
- Budgeted: The amount of budget assigned to this account left to allocate in this current date range. This means that, if your budgets correctly reflect reality, Current + Budgeted should be your actual cash flow at the end of the date range.

In the Transactions view, all transactions of the document for the current date range are listed. From there, you can add, change and remove transactions. This view is the most efficient view for adding a batch of transactions (if you have a pile of invoices and receipts to add, for example). Amount contains the value that is transferred by the transaction. From and To contain the name of the accounts affected by the transaction (if it’s a split transaction, names are comma separated). What these 3 columns mean is “This transaction transfers Amount from From and sent it to To”. For example, if From is “Checking” and To is “Groceries”, money is taken out of Checking and put in “Groceries”. For an income From would be “Salary” and To would be “Checking”.
Above the transactions list, there is a filter bar allowing you to see only certain types of transactions.
From and To cells have a little
at their right. Similarly to the Net Worth and Profit views, you can click on it to show the account displayed in the cell (if, for transactions having more than 2 splits, there’s more than one account in the cell, the first account is shown).
The Modification Time column shows the time at which the transaction was last modificated. This value is useful for finding mistakes you may have made in past edits. Your totals are wrong and you don’t know why? Sort your transaction by Modification Time to double-check if you’ve made a mistake in recent edits.

This view displays transactions from the perspective of a specific account. You can open an Account view by clicking on the
in other views. It lists transactions similarly to the Transactions view, but it only lists transactions that affect the shown account. Instead of a From and a To column, there is only a Transfer column (the other side(s) of the transaction). However, the Amount column is split into an Increase and a Decrease column. For example, if I have Checking shown and the Transfer is “Groceries” and the Decrease is “42”, it means that 42$ are taken from Checking and sent to Groceries. If the shown account is an asset or liability, there is also a Balance column, which shows the running balance of the account. The graph below shows the balance of the account for each day of the date range. If the shown account is an income or an expense, a bar chart similar to the Profit & Loss chart will be shown.
The Account view also has a filter bar, which behaves similarly to the one in the Transactions view, but with slight differences.
The Reconciliation button in the filter bar (only enabled for assets/liabilities) lets you toggle reconciliation mode on and off.
Transfer cells have a little
at their right. Similarly to the other views, you can click on it to show the account displayed in the cell. Unlike arrows from the Transaction view, this only cycles through the transaction’s split. Therefore, even when a transaction has more than 2 splits, continually clicking on that arrow will show all affected accounts, not just the first 2.
Depending on the selected date range, there might be a Previous Balance entry at the top of the table. This entry, like with bank account statements, shows the balance of the account at the beginning of the date range.
This view puts all accounts together and displays their entries for the current date range. The way it presents entries is pretty much identical to the Account view. This view is mainly for reporting purposes.
The filter field in the toolbar allows you to see all transactions that match the stuff you type in it. To use it, type something and press return. Only transactions that have one of its fields (description, payee, account, etc.) matching with what you typed will be shown. If you want to search specific fields, you can do so by prefixing your query with the name of the field, for example “payee: Apple”. The possible prefix values are:
Account and group prefixes are special because you can search for multiple values by separating account/group names with a comma. For example, “account: Visa, Mastercard” will look for all transactions affecting the Visa or Mastercard accounts.
In moneyGuru, you can print whatever is currently shown in any of the four views. You want to report a transaction listing for last year? Just set the current date range to last year, go to the Transactions view, and press ⌘P. moneyGuru automatically sizes the columns according to their content (columns with longer data are larger), trying to fit the most data in the page.