From 4b2ffefab1c4610f157a62e6e2564ce6206f3215 Mon Sep 17 00:00:00 2001 From: MonkeySon <10551896+MonkeySon@users.noreply.github.com> Date: Sat, 9 Nov 2024 06:44:35 +0100 Subject: [PATCH] Improve TradeRepublic PDF Importer (#4339) Add support for interest transaction with the identifiying line: "IBAN BUCHUNGSDATUM GESAMT" --- .../TradeRepublicPDFExtractorTest.java | 33 +++++++++++++++++++ .../pdf/traderepublic/Zinsabrechnung07.txt | 20 +++++++++++ .../pdf/TradeRepublicPDFExtractor.java | 13 ++++++-- 3 files changed, 64 insertions(+), 2 deletions(-) create mode 100644 name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/Zinsabrechnung07.txt diff --git a/name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/TradeRepublicPDFExtractorTest.java b/name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/TradeRepublicPDFExtractorTest.java index d88a7133ee..275db6e486 100644 --- a/name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/TradeRepublicPDFExtractorTest.java +++ b/name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/TradeRepublicPDFExtractorTest.java @@ -8082,6 +8082,39 @@ public void testZinsabrechnung06() hasTaxes("EUR", 0.00), hasFees("EUR", 0.00)))); } + @Test + public void testZinsabrechnung07() + { + TradeRepublicPDFExtractor extractor = new TradeRepublicPDFExtractor(new Client()); + + List errors = new ArrayList<>(); + + List results = extractor.extract(PDFInputFile.loadTestCase(getClass(), "Zinsabrechnung07.txt"), errors); + + assertThat(errors, empty()); + assertThat(countSecurities(results), is(0L)); + assertThat(countBuySell(results), is(0L)); + assertThat(countAccountTransactions(results), is(2L)); + assertThat(results.size(), is(2)); + new AssertImportActions().check(results, CurrencyUnit.EUR); + + // check interest transaction + assertThat(results, hasItem(interest( // + hasDate("2024-07-01T00:00"), // + hasSource("Zinsabrechnung07.txt"), // + hasNote("Zinsen 01.06.2024 - 11.06.2024 (4,00%)"), // + hasAmount("EUR", 21.02), hasGrossValue("EUR", 21.02), // + hasTaxes("EUR", 0.00), hasFees("EUR", 0.00)))); + + // check interest transaction + assertThat(results, hasItem(interest( // + hasDate("2024-07-01T00:00"), // + hasSource("Zinsabrechnung07.txt"), // + hasNote("Zinsen 12.06.2024 - 30.06.2024 (3,75%)"), // + hasAmount("EUR", 52.06), hasGrossValue("EUR", 52.06), // + hasTaxes("EUR", 0.00), hasFees("EUR", 0.00)))); + } + @Test public void testRescontoInteressiMaturati01() { diff --git a/name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/Zinsabrechnung07.txt b/name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/Zinsabrechnung07.txt new file mode 100644 index 0000000000..3f01e787bc --- /dev/null +++ b/name.abuchen.portfolio.tests/src/name/abuchen/portfolio/datatransfer/pdf/traderepublic/Zinsabrechnung07.txt @@ -0,0 +1,20 @@ +PDFBox Version: 1.8.17 +Portfolio Performance Version: 0.71.3.qualifier +----------------------------------------- +TRADE REPUBLIC BANK GMBH BRUNNENSTRASSE 19-21 10119 BERLIN +JKPzDZ ELEXWvPTL SEITE 1 von 1 +EfeCspUiGehWvSAZ 89 DATUM 01.07.2024 +8051 Ipgs VERRECHNUNGSKONTO 7964603079 +STEUER-ID 542208021 +ABRECHNUNG ZINSEN +zum 30.06.2024 +ÜBERSICHT +VERMÖGENSWERT EINKOMMENSART ZINSEN DATUM GESAMT +Cash Zinsen 4,00% 01.06.2024 - 11.06.2024 21,02 EUR +Cash Zinsen 3,75% 12.06.2024 - 30.06.2024 52,06 EUR +BUCHUNG +IBAN BUCHUNGSDATUM GESAMT +DE12321546856552266333 01.07.2024 74,08 EUR +Trade Republic Bank GmbH www.traderepublic.com Sitz der Gesellschaft: Berlin Geschäftsführer +Brunnenstraße 19-21 service@traderepublic.com AG Charlottenburg HRB 244347 B Andreas Torner +10119 Berlin USt-ID DE307510626 Gernot Mittendorfer \ No newline at end of file diff --git a/name.abuchen.portfolio/src/name/abuchen/portfolio/datatransfer/pdf/TradeRepublicPDFExtractor.java b/name.abuchen.portfolio/src/name/abuchen/portfolio/datatransfer/pdf/TradeRepublicPDFExtractor.java index 924ed5d7b9..7cdcb9d7c5 100644 --- a/name.abuchen.portfolio/src/name/abuchen/portfolio/datatransfer/pdf/TradeRepublicPDFExtractor.java +++ b/name.abuchen.portfolio/src/name/abuchen/portfolio/datatransfer/pdf/TradeRepublicPDFExtractor.java @@ -2528,9 +2528,13 @@ private void addTaxesStatementTransaction() // // VERRECHNUNGSKONTO DATUM DER ZAHLUNG BETRAG // DE12345678912345678912 28.09.2024 -0.27 EUR + // + // IBAN BUCHUNGSDATUM GESAMT + // DE12321546856552266333 01.07.2024 74,08 EUR + // // @formatter:on .section("date") // - .find("(IBAN BUCHUNGSDATUM GUTSCHRIFT NACH STEUERN|VERRECHNUNGSKONTO (VALUTA|WERTSTELLUNG|DATUM DER ZAHLUNG) BETRAG)") // + .find("(IBAN BUCHUNGSDATUM (GUTSCHRIFT NACH STEUERN|GESAMT)|VERRECHNUNGSKONTO (VALUTA|WERTSTELLUNG|DATUM DER ZAHLUNG) BETRAG)") // .match("^.* (?[\\d]{2}\\.[\\d]{2}\\.[\\d]{4}) (\\-)?[\\.,\\d]+( [\\w]{3})?$") // .assign((ctx, v) -> { ctx.put("date", v.get("date")); @@ -2883,11 +2887,16 @@ private void addInterestStatementTransaction() + "|INTEREST INVOICE)", // documentContext -> documentContext // // @formatter:off + // // IBAN BUCHUNGSDATUM GUTSCHRIFT NACH STEUERN // DE10123456789123456789 01.02.2023 0,88 EUR + // + // IBAN BUCHUNGSDATUM GESAMT + // DE12321546856552266333 01.07.2024 74,08 EUR + // // @formatter:on .section("date") // - .find("IBAN (BUCHUNGSDATUM|DATA EMISSIONE|BOOKING DATE) (GUTSCHRIFT NACH STEUERN|TOTALE|TOTAL)") // + .find("IBAN (BUCHUNGSDATUM|DATA EMISSIONE|BOOKING DATE) (GUTSCHRIFT NACH STEUERN|GESAMT|TOTALE|TOTAL)") // .match("^.* (?[\\d]{2}\\.[\\d]{2}\\.[\\d]{4}) [\\.,\\d]+ [\\w]{3}$") // .assign((ctx, v) -> { ctx.put("date", v.get("date"));