-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
CSVRecord failing when field/header is missing #5
Comments
Hi Enrique, The fact that different record implementations behave differently when encountering an 'unknown' reference is an issue that we'll address by the next release. Thanks for pointing this out! The "fuzzy" reference matching is something we'll have a closer look at, because also here consistent behaviour over every record type is desired. Best regards, |
Thank you very much for your answer, I appreciate it very much. I have created a PR that addresses this issue I mentioned above in case you want to consider my contribution in order to address this if that actually helps you in this process. Please, let me know your thoughts on this. |
Hi Enrique, |
Hi Gerald, This is excellent news. I've checked the new Record API, and it is great you thought of keeping trace of errored Records so that they can be reported independently. This is actually something I was going to need at some point down the line. Nonetheless, I've been trying to locate the matching changes RMLMapper, but I have been unable to trace new changes related to this on the development branch. Is there a chance you've got these changes in a feature branch so that I can have a look at them and start preparing my code according to this? Kind Regards, |
Hi Enrique, We're integrating these changes in RMLMapper, in parallel with some other changes/fixes. The moment these work together well, we'll merge them into the development branch. I'll let you know when that's done so you can move on. Maybe somewhere this week :). Best regards, |
This is great news Gerald! I highly appreciate this! |
Hi Enrique, by fixing this in DataIO I kind of opened a can of worms trying to integrate it in RMLMapper, especially some test cases need attention. We're working on this, but are not ready yet. I'll keep you posted. |
Hi Gerald, first of all Happy New Year! I was wondering if you've been able to make some progress on this front. I don't want to appear to be demanding by any means, so I was wondering if there would be anything I can do to help with this regard and the project in general. We'd be more than happy to collaborate on this. Kind Regards, |
Hi Enrique, the best for 2025! |
Hi, it's avaliable in the development branch of RMLMapper. So it will be in the next release. |
Hi Gerald! This is fantastic news, if the changes are already on the development branches, we've got more than enough for the time being to carry on working on this. Waiting for the release to happen in due time should not be an issue at all. Kind Regards, |
Hi all,
Us in Graph.Build have been users of your project for quite a long time already. We are working on a use case, where a mapping transformation for a CSV file expects to find a determinate field (defined by a column header), but in practicality, we cannot assume all the CSV files being transformed are complete in definition. They might have a column missing, as this column might be optional.
In these scenarios, we would like to carry on with the transformation even if it's partial, but under the current code, we see the following lines in the get method on CSVRecord, cause the whole transformation to break.
if (!this.data.containsKey(toDatabaseCase)) { throw new IllegalArgumentException(String.format("Mapping for %s not found, expected one of %s", toDatabaseCase, data.keySet())); }
We believe this code should be more resilient, log out the missing field, but still return an empty list, to avoid stopping the transformation running.
` @OverRide
public List get(String reference) {
String toDatabaseCase;
if (this.data.containsKey(reference.toUpperCase())) {
toDatabaseCase = reference.toUpperCase();
} else if (this.data.containsKey(reference.toLowerCase())) {
toDatabaseCase = reference.toLowerCase();
} else {
toDatabaseCase = reference;
}
if (!this.data.containsKey(toDatabaseCase)) {
logger.warn(String.format("Mapping for %s not found, expected one of %s", toDatabaseCase, data.keySet()));
return List.of();
}
String obj = this.data.get(toDatabaseCase);
The text was updated successfully, but these errors were encountered: