Neste artigo
Starting from Banana+ Dev Channel 10.1.25, a new command Report > Cash Flow Report has been introduced, offering a detailed analysis of liquidity changes recorded in accounting.
This tool allows you to monitor receipts and payments, including future ones, providing valuable insights into your company's financial strength and operational efficiency.
- The logic behind this function is based on comparing the balances of liquidity accounts and the movements of counterpart accounts, which usually represent revenues or expenses.
- By understanding how the movements in liquidity accounts correspond to net cash flows for each period, you can gain an accurate view of your financial situation at any time. This comparison provides valuable information for effective financial planning and informed decision-making, helping you maintain balanced cash flow and achieve your financial goals.
- Thanks to the forecast functionality, you can analyze the evolution of liquidity over the year, using data from existing entries and budget items.
Prerequisites
Currently the Cash Flow report functionality
- Is available in the Dev-Channel version, so please install the latest version of Banana Accounting+ Dev Channel.
- This extension works only with the Advanced Plan, you can request a 1 month promo code from our support service.
- The extension is currently in Beta Test, please check everything and report any problem.
The Cash Flow Table
To view the Cash Flow table:
- select the command from the menu Report > Cash Flow Report
 (if the command is not visible, check the prerequisites)
- set the parameters in the Cash Flow Report dialog and confirm with OK

Rows
Vertical structure of the report
- Each liquidity account- Total of all liquidity accounts (cash accounts)
 
- Counterpart accounts- Total of counterpart accounts (cash flow total changes)
 
- Difference (displayed only if the total of liquidity accounts differs from the total of counterpart accounts)
Some commands to filter the rows displayed in the table
- To display only the rows with an amount in the Current view
 |!Movement_?_C:xml!<> |!Balance_?_C:xml!<>
- To display only the rows with an amount in the Budget view
 |!Movement_?_B:xml!<> |!Balance_?_B:xml!<>
Columns
The columns with amounts
- Opening balance (only for liquidity accounts)
 The initial amount of the liquidity account for the period.
- Closing balance (only for liquidity accounts)
 The final amount of the liquidity account at the end of the period.
- Movements for the period- Inflows (hidden column)
 Indicates incoming money
- Outflows (hidden column)
 Indicates outgoing money
- Net Cash Flow- Liquidity accounts
 Calculated as Inflows minus Outflows.
 Represents the total of all revenues (positive amounts) and expenses (negative amounts) within the account for the considered period.
- Counterpart accounts
 The origin (positive amounts) and the destination (negative amounts).
 
- Liquidity accounts
 
- Inflows (hidden column)
Views
The report has three views
- Current
 Uses the opening balances and the actual transaction data.
- Budget
 Uses the opening balances and the data from the Budget table.
- Forecast- Uses the opening balance and the data from the transactions up to the day before the forecast start date.
- Uses the budget entries starting from the forecast start date (inclusive).
 
The View Forecast
The forecast combines current accounting data (Transactions table) with budget data (Budget table).
Example:
- In the Transactions table, movements are recorded up to the end of September.
- In the Budget table, the budget for the months of the year is recorded.
- If you set the forecast start date to October 1st, the program will calculate the forecast including:- Actual opening balance.
- Transactions from January through the end of September.
- Budget data starting from October 1st.
 
- The liquidity forecast will therefore use the actual liquidity account balances and calculate the forecast through the end of the year based on the budget data.
- The forecast can be particularly useful when combined with a monthly breakdown.
 If you use a monthly breakdown, you can view the projected cash flow for October, November, and December, starting from the actual data up to September.
Example of a report for the period 01.01.2025 - 30.06.2025
- Forecast start date: 01.04.2025
- 1st quarter amounts are based on actual transactions.
- 2nd quarter amounts are based on forecasts:- The opening balance of liquidity accounts is based on actual data.
- The net cash flow is calculated based on budget entries.
- The final balance (projection) is the sum of current and forecast data (transactions + budget).
 

Report logic
The report will show:
- For liquidity accounts:
 the total of all inflows and outflows for the period.
- For other accounts:
 the total of the entries that affected the liquidity accounts.
How the report works
- The user defines which accounts are liquidity accounts.
- The opening balance of the liquidity accounts is used as the starting value.
- For all entries in the Transactions and Budget tables:- The program only considers entries involving a liquidity account.
- The amount recorded in the liquidity accounts is analyzed individually for each account.
- The amount recorded in the counterpart accounts is also analyzed separately for each account.
 
Definition of counterpart account
A counterpart account is an account that does not belong to the list of liquidity accounts.
- For single-entry (debit/credit) records:
 the counterpart account is the one used in opposition to the liquidity account.
- For entries with multiple rows and different accounts:
 The position of the row including the liquidity account does not affect the decision to include or not the entry in the report.- The first liquidity account (whether debit or credit) is considered the main liquidity account.
- All other accounts used are considered counterpart accounts.
 
Logic for grouping entries
In the Transactions table, accounting movements are listed sequentially, without the possibility to manually define a start and end for each entry. Therefore, the program automatically determines when an entry starts and ends, as well as which accounts are part of it. This logic directly impacts the correct assignment of the counterpart to liquidity accounts.
Understanding the grouping mechanism of entries in Banana is essential for achieving an accurate interpretation and reducing any discrepancies reported in the cash flow report.
Errors and Differences
When the program is unable to determine the counter-account in a multi-line transaction, a difference is reported. This warning does not necessarily indicate an accounting error, but rather the inability to identify the exact counter-account.
In these cases, you can assist the program by specifying the liquidity account in square brackets on the relevant line. This action:
- allows the transaction to be included in the cash flow calculation.
- Acts only as a comment and does not affect the accounting result.
Managing differences
The inflows and outflows in liquidity accounts must always be associated with:
- a source account (for inflows, from where the money comes)
- a destination account (for outflows, where the money was transferred to).
For each entry (whether single or spread over multiple rows), the system reports an error when the total amounts recorded in the liquidity accounts do not match the total amounts assigned to the counterpart accounts.
Differences and errors can therefore arise from:
- Partial or missing counterpart assignments.
- Amount errors between liquidity movements and their counterparts.
Practical examples
Below are some examples of accounting entries split over multiple rows, involving the liquidity accounts 1020 Bank and 1000 Cash.
Although these entries are accounting-wise correct, they can generate ambiguities in cash flow calculation, highlighting a possible discrepancy between the liquidity balance and the total of the counterpart movements.
- Doc change (Doc column) - Example: entry over multiple rows with different docs. Report of a 360.00 CHF difference at row 1.
 - Date - Doc - Invoice - Description - Debit - Credit - Amount - Balance - 14.01.2025 - 1 - Various purchases - 1020 - 360.00 - -360.00 - 14.01.2025 - 2 - Purchase on 12.01 - 4000 - 30.00 - -330.00 - 14.01.2025 - 3 - Purchase on 13.01 - 4000 - 330.00 - Correction: indicate the liquidity account in square brackets in the second and third rows. - Date - Doc - Invoice - Description - Debit - Credit - Amount - Balance - 14.01.2025 - 1 - Various purchases - 1020 - 360.00 - -360.00 - 14.01.2025 - 2 - Purchase on 12.01 - 4000 - [1020] - 30.00 - -330.00 - 14.01.2025 - 3 - Purchase on 13.01 - 4000 - [1020] - 330.00 
 
- Change in invoice number (Invoice column) - Example: entry over multiple rows with different invoice numbers and an empty Doc column. Report of an 8,000.00 CHF difference at row 1.
 - Date - Doc - Invoice - Description - Debit - Credit - Amount - Balance - 18.01.2025 - Customer invoice collection - 1020 - 8,000.00 - 8,000.00 - 18.01.2025 - 4545 - Payment from customer 1 - 3000 - 3,000.00 - 5,000.00 - 18.01.2025 - 4546 - Payment from customer 2 - 3000 - 5,000.00 - Correction: indicate the liquidity account in square brackets in the second and third rows. - Date - Doc - Invoice - Description - Debit - Credit - Amount - Balance - 18.01.2025 - Customer invoice collection - 1020 - 8,000.00 - 8,000.00 - 18.01.2025 - 4545 - Payment from customer 1 - [1020] - 3000 - 3,000.00 - 5,000.00 - 18.01.2025 - 4546 - Payment from customer 2 - [1020] - 3000 - 5,000.00