Dynamische Kursdaten-URLs

Das ist dann wohl falsch. Man kann mehrere Marcos in der URL verwenden - aber immer nur von einem Typ. Wobei ich mir den aktuellen PR noch nicht im Detail angeschaut habe: vielleicht ändert sich das mit den weiteren Marcos.

Oben rechts gibt es :writing_hand: Edit Link. Die Dokumentation ist einfach ein anderes GitHub Projekt.

Neuerdings kannst Du die Typen auch durchmischen, wichtig ist nur, dass Du nicht mehr als einen “uneingeschränkt variablen” Typ hast (DATE + PAGE, die mit Macro#getVariableURLConstructor() != null). Das Problem ist, dass diese fortlaufend iterieren und Du (AFAIK) mehrere unbeschränkte Iterationen nicht sinnvoll zusammenlegen kannst.

Yahoo findet bei manchen Werten einfach nichts auch wenn es ein Kürzel gibt, wie bei diesem:
AT0000746748
IWTQ.F
676337

Daher überlege ich bereits, alle Werte von ariva zu nehmen.

Soweit ich das nun verstanden habe, wäre die passende URL:
https___www.ariva.de/espa_stock_biotec_a_%28eur%29-fonds/historische_kurse?boerse_id=8&month={DATE:yyyy-MM-32}
(Das Forum hat mir nicht erlaubt, den Link zu posten, daher musste ich ihn etwas abwandeln…)

Über boerse_id kann man bequem den Handelsplatz wählen.
Warum war nun das Format yyy-MM-32 ideal? Warum nicht 31 und warum überhaupt nicht -dd?
Wenn die Dokumentation nun in diesem Punkt noch aktuell ist, wird er beim ersten Mal rückwärts alle Kurse abrufen, bis keine mehr kommen. Das ist teuer für den Anbieter. Beim nächsten Mal würde er nur noch vom letzten vorhandenen Kurs aufwärts bis zum aktuellen Datum abrufen, also nur noch die fehlenden?

Kann man die URL der /historischen_kurse bei ariva nun auch beim Tab “Aktueller Kurs” verwenden, oder wird hier immer der aktuelle Kurs fehlen?

Hallo @Mssm und danke für Deine kritischen Fragen! (Heutzutage ist sowas Mangelware…)

Die Empfehlungen bzgl. des 32. und konstanten Monatstags in der Doku (die ich mittlerweile gelesen habe) hat Andreas von mir übernommen. Ich selbst habe sie aus folgendem Grund abgegeben:

Den klassischen Nutzer interessieren weder die Programm-Abläufe, noch die Konsequenzen, sondern nur, dass es geht – einmal eine URL zusammenbauen und fertig! Deshalb habe ich mir diese Empfehlungen überlegt, aus denen eine URL hervorgeht, die alles abdeckt:

  • Keine Daten vorhanden, gib mir alles
  • Habe die letzten 10 Jahre PP nicht aufgemacht (Alzheimer/Koma/JVA/…), gib mir ein Update
  • Habe PP erst gestern aufgemacht, bin ein aktiver Anleger

In den ersten 2 Fällen wäre eine tagesbasierte URL eine 30x größere Last für den Anbieter und 30x längere Wartezeit für den Nutzer als eine monatsbasierte. Im letzten Fall macht es nicht sonderlich viel aus, da manche auch mal gerne wöchentlich aktualisieren. Und selbst wenn nicht, macht es wenig aus, ob Du Dir nur den Kurs von gestern oder für 31 Tage holst. Die 31-Tage-Abfrage ist bei den Anbietern Standard. Wenn man das Intervall bspw. auf ein Jahr anhebt (sofern überhaupt vom Anbieter unterstützt), nützt das zwar in den Fällen 1 und 2, aber schadet im 3…

Und den Hintergrund zum 32. Monatstag… hat Andreas bereits hinreichend in der Doku zitiert.

Aktuelle Kurse: keine Ahnung, habe mich nie mit denen beschäftigt.

MfG, AK

@AndreasB Lass mich raten, TODAY ist für die altuellen Kurse?

Hallo @Al2Klimov, vielen Dank für diese Erweiterung, ich nutze die dynamische Kurs-URL sehr intensiv. Leider ist es mir bislang nicht gelungen, auch die isin oder wkn in der Kursabfrage zu eresetzen:
https://www.ariva.de/851399/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&clean_split=1&clean_split=0&clean_payout=0&clean_bezug=1&clean_bezug=0
und
https://www.ariva.de/US4592001014/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&clean_split=1&clean_split=0&clean_payout=0&clean_bezug=1&clean_bezug=0
funktionieren super für die IBM Kurse, aber
https://www.ariva.de/{isin}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&clean_split=1&clean_split=0&clean_payout=0&clean_bezug=1&clean_bezug=0
oder
https://www.ariva.de/{wkn}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&clean_split=1&clean_split=0&clean_payout=0&clean_bezug=1&clean_bezug=0
funktionieren nicht.
habe isin, ISIN, wkn und WKN versucht.
Mache ich etwas falsch oder funktionieren die Macros so nicht? Wäre echt toll, wenn dies irgendwie klappen würde!
Danke für die tolle Arbeit bisher,
Udo

Ich versuche die Frage noch einmal etwas kürzer:
https://www.ariva.de/851399/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}
funktioniert, aber
https://www.ariva.de/{wkn}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}
funktioniert bei mir nicht.
Sind {wkn} / {isin} bzw. {WKN} / {ISIN} in der Kurs-URLs für historische Kurse erlaubt?
Wäre für jeden Tipp dankbar!
Udo

Also wenn ISIN oder WKNgroß geschrieben werden, funktioniert es bei mir. Nur bei ARIVA funktioniert bei mir keiner deiner Links. Ursache dürfte sein, das PP die direkte URL erwartet und ARIVA eine Weiterleitung auf ᐅ IBM Historische Kurse | Historische Werte | ARIVA.DE vornimmt, damit rechnet PP mE nicht.

Habe mal rumgestöbert und das Fehlerprotokoll gefunden :wink:

Für die URL:

https://www.ariva.de/{ISIN}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&currency=EUR&clean_split=1&clean_payout=0&clean_bezug=1

habe ich folgendes Fehlerprotokoll gefunden:

Wed Jan 16 12:57:07 CET 2019
Während “ABInBev” ist ein interner Fehler aufgetreten.

java.lang.NullPointerException

at name.abuchen.portfolio.online.impl.variableurl.macros.ISIN.resolve(ISIN.java:17)

at name.abuchen.portfolio.online.impl.variableurl.iterators.DateIterator.resolve(DateIterator.java:80)

at name.abuchen.portfolio.online.impl.variableurl.iterators.DateIterator.hasNext(DateIterator.java:41)

at java.util.Iterator.forEachRemaining(Unknown Source)

at name.abuchen.portfolio.online.impl.variableurl.urls.DateURL.(DateURL.java:22)

at name.abuchen.portfolio.online.impl.variableurl.Factory.fromString(Factory.java:103)

at name.abuchen.portfolio.online.impl.HTMLTableQuoteFeed.internalGetQuotes(HTMLTableQuoteFeed.java:315)

at name.abuchen.portfolio.online.impl.HTMLTableQuoteFeed.updateHistoricalQuotes(HTMLTableQuoteFeed.java:289)

at name.abuchen.portfolio.ui.jobs.UpdateQuotesJob$2.run(UpdateQuotesJob.java:269)

at org.eclipse.core.internal.jobs.Worker.run(Worker.java:63)

Vielleicht hilft das ja weiter…

Wenn ich eine URL habe, wo bei den Variablen ?isin={ISIN} auftaucht wird {ISIN} aufgelöst.
Vielleicht funktioniert das nur in der Serveradresse nicht?? Wenn ich da ein eigenes Attribut einsetze gibt es folgende Fehlermeldung:
hatte 3m_company-aktie in tickerSymbol eingetragen, also den Wert, den Ariva in der URL ersetzt.

Illegal character in path at index 21: https://www.ariva.de/{tickerSymbol}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&currency=EUR&clean_split=1&clean_payout=0&clean_bezug=1

java.io.IOException: https://www.ariva.de/{tickerSymbol}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&currency=EUR&clean_split=1&clean_payout=0&clean_bezug=1
Illegal character in path at index 21: https://www.ariva.de/{tickerSymbol}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&currency=EUR&clean_split=1&clean_payout=0&clean_bezug=1

at name.abuchen.portfolio.online.impl.HTMLTableQuoteFeed.parseFromURL(HTMLTableQuoteFeed.java:369)

at name.abuchen.portfolio.online.impl.HTMLTableQuoteFeed.internalGetQuotes(HTMLTableQuoteFeed.java:328)

at name.abuchen.portfolio.online.impl.HTMLTableQuoteFeed.updateHistoricalQuotes(HTMLTableQuoteFeed.java:289)

at name.abuchen.portfolio.ui.jobs.UpdateQuotesJob$2.run(UpdateQuotesJob.java:269)

at org.eclipse.core.internal.jobs.Worker.run(Worker.java:63)

Caused by: java.net.URISyntaxException: Illegal character in path at index 21: https://www.ariva.de/{tickerSymbol}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&currency=EUR&clean_split=1&clean_payout=0&clean_bezug=1

at java.net.URI$Parser.fail(Unknown Source)

at java.net.URI$Parser.checkChars(Unknown Source)

at java.net.URI$Parser.parseHierarchical(Unknown Source)

at java.net.URI$Parser.parse(Unknown Source)

at java.net.URI.(Unknown Source)

at name.abuchen.portfolio.online.impl.HTMLTableQuoteFeed.parseFromURL(HTMLTableQuoteFeed.java:362)

… 4 more

Ich kann den Bug nachvollziehen. Aktuell kann man das DATE Makro nicht zusammen mit einem “Wertpapier” Makro (ISIN, TICKER, …) mischen. Das behebe ich.

(BTW, für die Markos gibt es eine Seite in der (noch) überschaubaren Hilfe - es heißt TICKER und nicht tickerSymbol)

Hallo @AndreasB,
hab mir deinen neuesten commit geholt, klappt jetzt super.
Die Anleitung hatte ich gesehen, tickerSymbol hatte ich mir selber als Attribut definiert und damit experimentiert.
Danke für den schnellen Patch.
Ist ne echt tolle Arbeit, die Du hier leistest, Danke!!
Udo

1 Like

Der Fix ist jetzt mit Version 0.37.0 auch veröffentlicht.

Hi UdoJ, wie sieht nun deine URL aus? Ich suche auch schon lange nach einer generischen URL, die ich (am liebsten per globalen default) für alle neuen Positionen verwenden kann, und die per ISIN oder WKN sucht.

Wenn ich mich z.B. für ISIN DE000A0D9PG7 auf Yahoo verlasse, so passen im Chart meine Buy und Sellpunkte überhaupt nicht zum Chart, gut 30% daneben. Ich dachte zunächst an ein Währungsproblem, aber mit Symbol WXIY.F ist es der Kurz aus Frankfurt, der in EUR sein sollte. IM Grunde möchte ich einfach alle Kurse von Tradegate, da ich dort auch vorwiegend handle.

Was mich noch wundert, die empfohlene URL mit {DATE:yyyy-MM-32} liefert Kurse bis 05.2018. Wenn man 32 durch 31 ersetzt, kommen Kurse bis 08.2016:
https:__www.ariva.de/tbf_global_technology-fonds/historische_kurse?boerse_id=131&month={DATE:yyyy-MM-32}

Und das, obwohl ariva bei dieser URL einen Wert liefert:
https:__www.ariva.de/tbf_global_technology-fonds/historische_kurse?boerse_id=131&month=2016-11-32

Hallo Mssm,
meine Standard-URL ist

https://www.ariva.de/{ISIN}/historische_kurse?boerse_id=1&month={DATE:yyyy-MM-32}&currency=EUR&clean_split=1&clean_payout=0&clean_bezug=1

Die erledigt alle meine Aktien.
Bei neuen Aktien hole ich mir die historischen Kurse von Ariva direkt auf der Webseite und importiere die als CSV, da kriegt man die Listen meist besser. Danach wirkt die URL perfekt.
Man kann noch optimieren bei manchen Aktien indem man mit der boerse_id spielt, 1 ist Frankfurt.

Bei deiner ISIN DE000A0D9PG7 hab ich grad geschaut, da wäre boerse_id=8 (Fondsgesellschaft) optimal, da gehen die Kurse bis 05/2005 :wink:

Für Währungen habe ich

https://www.ariva.de/{TICKER}/historische_kurse?boerse_id=130&month={DATE:yyyy-MM-32}&clean_split=1&clean_payout=0&clean_bezug=1

mit der WKN als Tickersymbol (WKN und ISIN kann man bei Währungen nicht eintragen. Auch hier die richtige Boerse wählen.

Hoffe, das hilft Dir weiter!

viel Spaß beim Probieren,
Udo

3 Likes

Vielen Dank, damit läuft es nun auch überall, wenn man im Zweifelsfall an der boerse_id= etwas nachjustiert.
Schön wäre es, wenn man global eine Default-URL hinterlegen könnte, damit man nicht alle Werte editieren muss.
Dass hier immer eine Webseite geparst wird, hört sich auf Dauer nicht sehr stabil an, hoffen wir, dass avira nicht so oft das Layout ändert. Eine echte API wäre natürlich schicker, sehr seltsam, dass es sowas in der Börsenwelt noch nicht frei gibt. In Google Docs Tabellen habe ich mir immer mit =GOOGLEFINANCE(“FRA:NFC”;“price”) geholfen, da gingen aber immer nur die Werte aus Frankfurt.

Eine Frage noch zu deiner URL. Wie geht man denn über den Tag mit den Live-Kursen um? Ich schätze, damit ist das Tab “Latest Quote” gemeint, hier steht per default immer “(same as historical quotes)”. Liefern die Historical URL denn auch stundengenaue Kurse? Aktualisiert man die Avira Seite, dann wackelt immer der oberste Wert des aktuellen Tages, ich vermute also, dass dies der Live-Kurs ist. Wünschenswert wäre hier aber für den aktuellen Tag auch eine Historie. Allerdings sehe ich bei PP keine Tagescharts. Unter All Securities, dann einen Wert wählen, sieht man unten im Chart als kleinsten Zeitraum “1M”.
Auch etwas seltsam, dass in der Ansicht “Reports->Statement of Assets” gar kein Chart zu sehen ist. Hier geht es ausschließlich um eine Tabelle des aktuellen Portfolios mit Auswertung der Performance. Dennoch ist die gleiche Chart-Ansicht hier auch interessant, wenn man durch die Werte klickt.

Hallo Mssn,
freut mich, dass Dir die URLs helfen.
Ich bin auch nur Anwender, solltest Du Wünsche zur Erweiterung haben, kann man das hier im Forum wohl auch posten.
Zu den Fragen, die ich beantworten kann:
Bei Ariva scheint regelmäßig der Tageskurs aktualisiert zu werden, deshalb habe ich auch bei den aktuellen Kursen “wie historische Kurse” ausgewählt. Die aktuellen Kurse werden aber nicht gespeichert, das ist immer der letzte Wert. Da ich eher Langfristanleger bin und kein Daytrader ist das für mich auch absolut ok. Wenn ich mal handeln will, dann nehme ich die Trading-Tools der Banken. Also auch kein Tageschart… :wink:
Ich hab mal versucht als aktuellen Kurs Yahoo zu nehmen, aber das war mir zu viel recherche wegen der Tickersymbole, das hat mir nicht gefallen. Mache das mit den Ariva-Kursen jetzt schon ne WEile und läuft bisher wirklich stabil.

Wenn Du durch die Werte klicen willst und Charts anschauen, dann musst Du unter Performance auf Wertpapiere gehen, da sind Deine Aktien mit Charts.
Du hast aber recht, ich würde mir auch auf der Vermögensübersicht die Charts wünschen, das wäre dann in sich schlüssiger.
Vielleicht machen wir mal nen Thread auf und fragen danach, bei manchen Dingen ist @AndreasB sehr schnell in der Umsetzung, wenn er das auch sinnvoll findet!

1 Like

Hallo @Mssm,

Der Hacken dabei ist das hier Google seine eigene Datenbank anzapfen kann. In allen anderen kostenlosen Varianten wie Alpha Vantage oder Yahoo steht und fällt es i. d. R. mit der Datenqualität. Und, wer zahlt schafft an :wink:

Der Punkt hier ist, woher sollten die Daten kommen? Unabhängig davon liegt der Fokus von Portfolio Performance auf die langfristige Anlage, da spielt der Tageskurs keine wirkliche Rolle. Für das Daytraiding gibt es bereits genügend Alternativen, die das ganze besser abbilden können.

Welche Grafik würdest du den hier sehen wollten?

Gruß
Marco

Hallo @Ragas,

ich muss gleich weg, deshalb hier schnell ein Zwischenruf… :wink:
Ich würde mir in dort die Kursdiagramme wünschen, wie unter Performance/Dividenden.
In der Assetübersicht würde ich gerne durch die Aktien klicken und mir die Charts ansehen… :wink:

vG Udo

Auch wenn der Fokus auf langfristiger Anlage liegt und ich selten Positionen am gleichen Tag öffne und schließe, ist das Verfolgen des Portfolios über den Tag auch nicht viel mehr als das, was PP heute schon kann. Wo diese Werte herkommen sollen, ist das gleiche Problem wie auch bei historischen Kursen. Es wäre nur zu überlegen, wenn sich über den Tag hunderte Kurse ansammeln, ob man die für die Langzeit-Charts irgendwann aufräumt und nur noch den Tageskurs behält, wenn ein Kurs z.B. 2 Wochen zurück liegt, Stichwort Database-Cleanup.

UdoJ, wie gehst du mit Split um? Deine URL bereinigt diese, d.h. der Chart hat keinen Sprung. Dafür hängen alte Buys und Sells allerdings in der Luft. Ist das nur eine optische Frage, und kann PP das dennoch richtig berechnen, auch wenn man Positionen über einen Split hinaus gehalten hat?
Wenn ich die URL mit clean_split=0 mache, sind die alten Orders wieder auf dem Graph, der springt dann allerdings beim Split, womit man ja auch leben kann.