Comments (14)
I also experience similar issues.
When I import similar transactions with CSV it actual updates older ones with the newer date. For some this might occur as deleting, but for me the transactions note does not change.
Also, when you have locked transactions after reconcile, the same CSV is not updating old transactions but also not adding new ones.
from actual.
It breaks my OFX imports the same way for me too. If this behavior is by design, then the de-dupe logic is broken. Two transactions with
1/ different dates
2/ different note/memo
3/ same payees
4/ same amounts
should not be considered duplicates.
from actual.
where those older transactions imported via ofx?
from actual.
yes, i did not research this issue yet, but it happens when similar transactions are made on close dates
from actual.
Interesting. Would you mind providing reproduction steps (perhaps an existing budget file + an example OFX import)?
Transactions should not be deleted on import. Only create & update operations should be happening. So I'm curious to see how this could be reproduced.
from actual.
Hi @MatissJanis
I can confirm I experience a similar issue but with CSV imports where the original transaction was also imported by CSV. I find it happens when the transaction is for the same dollar value and description but different dates but have also seen it for a different date, different description and same dollar value. The one I notice the most is my loan payment and coffee shop purchases. If I had a loan payment for $500 on the 15/3/24 already imported and reconciled then when I import the next week which has a loan repayment on the 22/3/24 for the same amount the entry for the 15/3/24 disappears. I don't think it deletes but I think the date gets adjusted to the 22/3/24 and no transaction is imported meaning the balance is now off by $500 as you are missing a transaction. You can find out which ones have done this since I find they are not bolded like the other freshly imported transactions. Let me know if you need some sample csv's to replicate and I can pull some from my bank and set some fictitious descriptions.
from actual.
I can confirm that for me it is the same with ofx import, usually my same amount daily coffee transactions and lunch transactions are gone.
from actual.
Missing reproduction steps.
from actual.
Steps to reproduce.
- Create an off budget account with a zero dollar starting balance.
- Import week1.csv and confirm total balance is $465 and that the first transaction is on the 11/03/2024 and the last is on the 17/03/2024.
- Import week2.csv
This should show that all transactions get overwritten/updated even the coffee shop purchases that have different descriptions.
week1.csv
week2.csv
Client version: v24.3.0
Server version: v24.3.0
from actual.
@britto89 that functionality is actually by design. The imports have de-dupe logic that attempts to match the new imported transactions to the old ones. And if they match - it updates their details. It matches by date and amount. Which in the week1/2 case doesn't work well because.. all the amounts are the same.
For your use-case my recommendation would be to perform imports with a months worth of data. And then to allow the de-dupe logic to take care of removing duplicates & creating new transactions. Instead of doing weekly exports.
However, I'm still missing reproduction steps for the root-issue reported here: transactions getting deleted. Please provide reproduction steps to delete transactions on import.
from actual.
Cant import anything, it has totally trashed my accounts.
from actual.
@britto89 that functionality is actually by design. The imports have de-dupe logic that attempts to match the new imported transactions to the old ones. And if they match - it updates their details. It matches by date and amount. Which in the week1/2 case doesn't work well because.. all the amounts are the same.
For your use-case my recommendation would be to perform imports with a months worth of data. And then to allow the de-dupe logic to take care of removing duplicates & creating new transactions. Instead of doing weekly exports.
However, I'm still missing reproduction steps for the root-issue reported here: transactions getting deleted. Please provide reproduction steps to delete transactions on import.
Well it might technically not be a delete, it probably just does not import similar transactions. I think all reproduction steps are already in this thread and it's getting clear what happens. I am importing monthly once and some transactions are so far always lost, usually the ones that are almost similar just like how other people described it.
We could also say that the de-duplication logic is rather harmful in the current implementation. Anyhow it should not de-duplicate anything as I import full months and there is in my case no overlap or anything that would need such a logic.
from actual.
@MatissJanis I think the needs info label can now be removed.
from actual.
👋 I understand how the existing de-duplication logic can be quite frustrating under some circumstances. The dedupe logic has been unchanged basically since the very inception of open-source Actual and while it's not absolutely perfect, IMO it does handle the majority of the scenarios that occur when doing file imports.
Here's a feature request I have opened: the ability to disable the dedupe logic. Which would give you folks a solution. PRs with the implementation are welcome!
The dedupe logic works quite well if larger time-ranges are used. So my recommendation for now (until someone builds the feature) would be to import larger time ranges. The specific time-range depends on your use case, but here's the logic you can follow: "previous time range * 2" (i.e. if you usually import a month - try importing the current month + previous in the same go; if you usually import a week - try importing this week + previous week).
I will close this bug report in favour of the feature ticket.
from actual.
Related Issues (20)
- [Bug]: Unable to use the date input on repeating schedules
- [Feature] Read out what's entered as remittanceInformationStructured when syncing your bank transactions with GoCardless so that it can be imported into the "Notes" section in Actual HOT 2
- [Bug]: Hidden categories cannot be selected in category dropdown, even when searching. HOT 1
- [Feature] Payee page: a button to view all transactions of selected payee(s) HOT 1
- [Bug]: Bank-sync operations are not e2e encrypted
- [Bug]: Menus blend in with other elements HOT 9
- [Bug]: Category dropdown selection gets messed up by hidden categories HOT 3
- [Bug]: Reverse proxy header auth still prompts for password HOT 4
- [Feature] import or sync transactions from MoneyMoney app on MacOS HOT 1
- [Bug]: Hidden Category Lost HOT 5
- [Bug]: column titles incorrect when selecting transactions and resizing window
- [Feature] Option to create a new category when adding a transaction if a category doesn't exist HOT 1
- [Feature] Allow option to exclude off budget accounts from "All Accounts" total. HOT 3
- [Feature] Add support for Trading 212 ISA Account sync HOT 1
- [Bug]: Service Worker preventing correct execution of bootstrap when using NGINX reverse proxy HOT 2
- [Bug]: SimpleFIN sync only executes if MX provides org domain HOT 1
- [Bug]: error message while syncing HOT 2
- [Bug]: ofx amount parsing does not work for foreign number formats HOT 3
- [Feature] Autofill "last used value" in Notes, Category and Amount HOT 1
- [Bug]: GoCardLess not working anymore ?
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from actual.