NEWS
Auslesen und Filtern der autobahn.api von bund.dev
-
@mickym sagte in Auslesen und Filtern der autobahn.api von bund.dev:
$.warning[coordinate.lat > 51.0 and coordinate.lat < 54.4].{"ID": identifier, "Titel":title, "Verzögerung": delayTimeValue, "Durchschnittsgeschwindigkeit" : averageSpeed}[]
Will man den Breitengrad auch noch filtern, dann halt diesen mit eckigen Klammern auch noch in den Filterausdruck aufnehmen.
Hier noch zur Übersicht die Variante, um nach Längen- und Breitengrad zu filtern und übersichtlicher geschrieben:
$.warning[(coordinate.lat > 51.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10)].{ "ID": identifier, "Titel":title, "Verzögerung": delayTimeValue, "Durchschnittsgeschwindigkeit" : averageSpeed}[]
Und hier zum Testen: https://try.jsonata.org/Ib1WHb2eD
Wenn man will, dass nur Einträge kommen, bei den auch eine Verzögerung auftaucht oder andere Kriterien, dann einfach in den Filter aufnehmen:
$.warning[(coordinate.lat > 41.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10) and delayTimeValue].{ "ID": identifier, "Titel":title, "Verzögerung": delayTimeValue, "Durchschnittsgeschwindigkeit" : averageSpeed}[]
Hier werden dann nur die Einträge genommen, bei den eine Verzögerung angegeben ist.
https://try.jsonata.org/aMukuTjlf
Übrigens wenn man die Werte nicht als Strings, sondern gleich als Zahlen braucht, dann kann man diese auch gleich in Zahlen mittels JSONATA umwandeln.
$.warning[(coordinate.lat > 41.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10) and delayTimeValue].{ "ID": identifier, "Titel":title, "Verzögerung": $number(delayTimeValue), "Durchschnittsgeschwindigkeit" : $number(averageSpeed)}[]
-
@mickym said in Auslesen und Filtern der autobahn.api von bund.dev:
Und ich hoffe, dass das wieder mal ein Beispiel ist, dass es wert ist sich mit JSONATA zu beschäftigen und wieviel Code schreiben, man sich damit spart.
Das ist ja wirklich absolut genial. Die Funktion JSONata kannte ich nicht. Ganz vielen Dank für deine enorme Hilfe! So einfach kann es sein.
Letztendlich habe ich inzwischen auch gesehen, würde mir sogar der reine JSONata Konvert/Filter reichen daher Jarvis JSON Tables ausgeben kann.
Ich werde ma schauen ob ich das JSON nehme oder die Datenpunkte. Die Datenpunkte würde mir noch etwas Spielraum geben wie z.B. das füllen der Verzögerung mit dem Text "0 Minuten" - wenn keine Verzögerung angegeben ist im JSON.
Aber das wird vermutlich auch mit JSONata gehen. Muss ich mir morgen mal in Ruhe anschauen.
Ich wollte hier erst mal Feedback geben.
-
@gutgut30 sagte in Auslesen und Filtern der autobahn.api von bund.dev:
Ich werde ma schauen ob ich das JSON nehme oder die Datenpunkte. Die Datenpunkte würde mir noch etwas Spielraum geben wie z.B. das füllen der Verzögerung mit dem Text "0 Minuten" - wenn keine Verzögerung angegeben ist im JSON.
Das kannst Du auch easy machen. Wenn im neuen Objekt ein Wert "undefined" ist, dann fällt die Eigenschaft weg. Du kannst aber prüfen und dann bei Nichtvorhandensein einen Wert setzen. Und natürlich Text ergänzen.
warning[(coordinate.lat > 50.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10)].{ "ID": identifier, "Titel":title, "Verzögerung": (delayTimeValue ? delayTimeValue : "0") & " Minuten", "Durchschnittsgeschwindigkeit" : averageSpeed}[]
Das setzt die Eigenschaft "Verzögerung" wenn kein delayTimeValue vorhanden ist, immer auf "0" und ergänzt dann den Text mit " Minuten".
https://try.jsonata.org/N3PeUO-am
-
Ebenfalls von mir auch ein genial und vielen Dank dafür.
Ein Frage hätt ich aber auch noch, wie bekomm ich den Teil der "description": "Angespannte Verkehrslage,......." noch mit in die Abfrage?
Edit: Ich habs hinbekommen und zwar so:
$.warning[ (coordinate.lat > 50.0 and coordinate.lat < 52.0) and (coordinate.long > 6.0 and coordinate.long < 8.5) and delayTimeValue ].{ "Beschreibung": description }[]
Ergebnis:
[ { "Beschreibung": [ "Beginn: 19.03.25 um 06:12 Uhr", "Ende: 19.03.25 um 10:53 Uhr", "", "Angespannte Verkehrslage, von 19.03.2025, 06:12, bis 19.03.2025, 10:53", "A4: Olpe -> Köln, zwischen 6.4 km hinter AS Reichshof/Bergneustadt und 0.2 km vor Hömeler Feld", "", "Langsamer Verkehr", "Reisezeitverlust: 3 Minuten", "Durchschnittsgeschwindigkeit: 38 km/h" ] } ]
Die Frage ist jetzt nur, ich würde gern die einzelnen Zeilen jeweils in ein DP schreiben.
Also
"Beginn:...." in ein DP
"Ende:..." in ein DPusw.
Ist das möglich?
-
@icebear sagte in Auslesen und Filtern der autobahn.api von bund.dev:
Ebenfalls von mir auch ein genial und vielen Dank dafür.
Ein Frage hätt ich aber auch noch, wie bekomm ich den Teil der "description": "Angespannte Verkehrslage,......." noch mit in die Abfrage?
Na in dem Du es einfachh in Dein neues Objekt mitaufnimmst.
Entweder vollständig:
warning[(coordinate.lat > 50.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10)].{ "ID": identifier, "Titel":title, "Verzögerung": (delayTimeValue ? delayTimeValue : "0") & " Minuten", "Durchschnittsgeschwindigkeit" : averageSpeed, "Beschreibung": description}[]
Na Du hast es Dir ja schon selbst beantwortet.
-
@icebear sagte in Auslesen und Filtern der autobahn.api von bund.dev:
Also
"Beginn:...." in ein DP
"Ende:..." in ein DPJa das geht auch - Ich würde aber nicht die Beschreibung aufteilen, sondern woher die einzelnen Daten wirklich kommen.
Grundsätzlich kannst Du aber natürlich auch die Beschreibung auseinanderfuseln.
Zum Beispiel:
$.warning[(coordinate.lat > 50.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10)].{ "ID": identifier, "Titel":title, "Verzögerung": (delayTimeValue ? delayTimeValue : "0") & " Minuten", "Durchschnittsgeschwindigkeit" : averageSpeed, "Beginn": description[0], "Ende": description[1] , "Beschreibung": description#$i[$i in [3..$count(%.description)]]~>$join("\n")}[]
Das holt Dir aus den ersten beiden Zeilen die Beschreibung raus. Die eigentliche Beschreibung wird dann von Zeile 3 bis Ende gesetzt. Dann habe ich das Array noch aufgelöst und einen String mit \n als Zeilenvorschub eingefügt.
Das erzeugt dann folgende Objekte:
{ "ID": "undefined--vi-zus.2024-07-04_10-30-00-000.f_408.de0", "Titel": "A7 | Uttrichshausen - Steinborntal", "Verzögerung": "0 Minuten", "Beginn": "Beginn: 04.07.24 um 10:30 Uhr", "Ende": "Ende: 31.03.25 um 09:00 Uhr", "Beschreibung": "Zusammengesetzte Verkehrsinformation, von 04.07.2024, 10:30, bis 31.03.2025, 09:00\nA7: Würzburg -> Fulda, zwischen 1.4 km hinter Uttrichshausen und 1.2 km vor Steinborntal\n\nA7 Würzburg - Fulda zwischen Raststätte Uttrichshausen Ost und Rastplatz Riederberg in beiden Richtungen Bauarbeiten, geänderte Verkehrsführung, vorübergehende Begrenzung der Fahrbahnbreite auf 3,25 m, Standstreifen gesperrt, bis 31.03.2025 09:00 Uhr\nEnde" }
Und diese kannst Du ja als Attribute aus den Objekten wieder rausholen und in einzelne Datenpunkte schreiben.
Hier wieder der Link zu Exerciser:
https://try.jsonata.org/h5VREUYi5Da kannst Du es ja alles ausprobieren.
Wie Du siehst kannst Du auch alle Stringmanipulationen direkt bei Erzeugnung des Objektes anwenden - vergleichen Ende mit Beginn aus der Beschreibung:
$.warning[(coordinate.lat > 50.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10)].{ "ID": identifier, "Titel":title, "Verzögerung": (delayTimeValue ? delayTimeValue : "0") & " Minuten", "Durchschnittsgeschwindigkeit" : averageSpeed, "Beginn": description[0] ~> $substringAfter(": "), "Ende": description[1] , "Beschreibung": description#$i[$i in [3..$count(%.description)]]~>$join("\n")}[]
Du siehst dann wird bei Beginn der String aus dem Array erst nach dem Doppelpunkt und dem Leerzeichen in das Attribut Beginn geschrieben:
{ "ID": "undefined--vi-zus.2024-07-04_10-30-00-000.f_408.de0", "Titel": "A7 | Uttrichshausen - Steinborntal", "Verzögerung": "0 Minuten", "Beginn": "04.07.24 um 10:30 Uhr", "Ende": "Ende: 31.03.25 um 09:00 Uhr", "Beschreibung": "Zusammengesetzte Verkehrsinformation, von 04.07.2024, 10:30, bis 31.03.2025, 09:00\nA7: Würzburg -> Fulda, zwischen 1.4 km hinter Uttrichshausen und 1.2 km vor Steinborntal\n\nA7 Würzburg - Fulda zwischen Raststätte Uttrichshausen Ost und Rastplatz Riederberg in beiden Richtungen Bauarbeiten, geänderte Verkehrsführung, vorübergehende Begrenzung der Fahrbahnbreite auf 3,25 m, Standstreifen gesperrt, bis 31.03.2025 09:00 Uhr\nEnde" }
-
Vielen Dank, das funktioniert super, auch mit dem Blockly.
Jetzt müsste ich das Blockly nur noch dahingehend erweitern, wenn ich mehrere Meldung auf der gleichen Autobahn in meinem Bereich hab.
Im Moment schreib er halt nur die letzte Meldung von mehreren in den DP (is ja auch logisch). -
@icebear Wieso Du bekommst doch ggf. mehrere Objekte als Array. Da würde ich dann einen Datenpunkt machen, in dem ich die Anzahl der Elemente reinschreibe.
Die Objekte kann man dann (gibt glaub auch ein JS Script) - aber ansonsten nimmst mein NodeRed Flow in einzelne Datenpunkte schreiben.Mit NodeRed könnte ich Dir leicht eine fertige Lösung präsentieren - das JS finde ich nicht.
-
@mickym said in Auslesen und Filtern der autobahn.api von bund.dev:
Mit NodeRed könnte ich Dir leicht eine fertige Lösung präsentieren
Das Node-Red würd ich nehmen
-
@icebear sagte in Auslesen und Filtern der autobahn.api von bund.dev:
@mickym said in Auslesen und Filtern der autobahn.api von bund.dev:
Mit NodeRed könnte ich Dir leicht eine fertige Lösung präsentieren
Das Node-Red würd ich nehmen
Also nur aus der Beschreibung Beginn, Ende und die Beschreibung selbst?
Also so?
-
-
@icebear OK - Also - Du musst natürlich im NodeRed Adapter zulassen, dass Fremdobjekte erstellt werden.
Gelöscht werden können Datenpunkte nicht - zumindest nicht in NodeRed. Sprich die Anzahl der Warnungen, die aktuell sind werden in einem eigenen Datenpunkt gespeichert.
Also hast Du 15 Meldungen - und die adressierst Du von 0-14.
Die Debug-Nodes kannst Du bei Bedarf - durch Betätigung der Schaltfläche Ausgaben tätigen lassen oder lässt es bleiben.
Hier der Flow zum Import:
In der Inject Node am Anfang - kannst Du die Autobahn und den Filter spezifizieren:
Die Autobahn wird in den Datenpfad übernommen:
WICHTIG:
Wie gesagt - Datenpunkte können mit NodeRed nicht gelöscht werden. Sprich Du musst über die Anzahl prüfen, welche Datenpunkte überhaupt aktuell bzw. relevant sind.Die DebugNodes kannst Du natürlich löschen - die nehm ich immer, um zu schauen, ob die Zwischenergebnisse stimmten.
-
Warte mal - ich glaub mit dem Filter stimmt noch was nicht.
Ja der Filter muss evaluiert werden - also in der Filterchange Node folgendes ändern:
payload.warning[$eval($$.filter)].{ "ID": identifier, "Titel":title, "Verzögerung": (delayTimeValue ? delayTimeValue : "0") & " Minuten", "Durchschnittsgeschwindigkeit" : averageSpeed, "Beginn": description[0] ~> $substringAfter(": "), "Ende": description[1] ~> $substringAfter(": "), "Beschreibung": description#$i[$i in [3..$count(%.description)]] ~> $join(" ") }[]
Hier nochmal der ganze Flow:
-
Super Vielen Dank für deine Arbeit, ich werde das testen und berichten.
-
@icebear sagte in Auslesen und Filtern der autobahn.api von bund.dev:
Super Vielen Dank für deine Arbeit, ich werde das testen und berichten.
Ja noch einen Filter, als Sicherheitsabfrage, wenn keine Ergebnisse vorhanden sind.
Sonst stürzt der NodeRed Adapter ab .
Also diesen Flow bitte verwenden:
-
@mickym said in Auslesen und Filtern der autobahn.api von bund.dev:
:title,
"Verzögerung": (delayTimeValue ? delayTimeValue : "0") & " Minuten"Funktioniert perfekt. Ich schreibe inzwischen auch einfach das JSON in den Datenpunkt und gebe es in Jarvis als einfache JSON Liste aus. Das reicht mir vollkommen.
An einer Kleinigkeit habe ich mir aber nun dann doch noch die Zähne ausgebissen und bin mit Google und KI nicht zum Ziel gekommen...
Ich gehe davon aus, dass der Wert "isBlocked" in der Rückgabe für eine Vollsperrung steht. Wie bekomme ich es hin, dass ich in der Ausgabe bei false den Wert gar nicht habe, bei true aber ein Wert "Vollsperrung" : "ja" kommt?
Ich hab es replacen können, aber eine Selektion mal "Vollsperrung" und mal nicht mit auszugeben hat mich dann leider überfordert.
-
@gutgut30 sagte in Auslesen und Filtern der autobahn.api von bund.dev:
ch gehe davon aus, dass der Wert "isBlocked" in der Rückgabe für eine Vollsperrung steht. Wie bekomme ich es hin, dass ich in der Ausgabe bei false den Wert gar nicht habe, bei true aber ein Wert "Vollsperrung" : "ja" kommt?
Ich hab es replacen können, aber eine Selektion mal "Vollsperrung" und mal nicht mit auszugeben hat mich dann leider überfordert.$.warning[(coordinate.lat > 51.0 and coordinate.lat < 54.4) and (coordinate.long > 9.0 and coordinate.long < 10)].{ "ID": identifier, "Titel":title, "Vollsperrung": isBlocked="false" ? undefined : "ja"}[]
https://try.jsonata.org/yQ2hFUzFf
Ach hatte ich schon erwähnt, dass JSONATA so genial ist und nur Eigenschaften anzeigt, die definiert sind?
-
Ich möchte euch herzlich danken - ich habe nun fast das, was ich haben wollte.
Ich lese 3 Autobahnen aus, filtere auf mein Teistück und kombiniere diese. Anschließend erscheinen die Meldungen auf meiner VIS. Mein Lese-Blockly sieht so aus:
Das Kombinieren der Meldungen so (und, ja, es geht sicher geschickter...):
Die JSONata, je nach Autobahn, so (füllen von Verzögerung, Splitten des Titels):
$.warning[(coordinate.lat > 1.1 and coordinate.lat < 99.999)].{"Autobahn":$substringBefore(title, " |"),"Teilstück":$substringAfter(title, " | "),"Verzögerung": (delayTimeValue ? delayTimeValue : "0") & " Minuten","Vollsperrung": isBlocked="false" ? undefined : "ja"}[]
Und was ich damit am Ende bezwecken wollte:
Was ich jetzt noch versuchen werde:
-
das zusammenbauen der Kombination besser bauen
-
nur die Meldungen ausgeben die entweder Verzögerung von mehr als 2 Minuten haben ODER eine Vollsperrung ergeben. Das dürfte eigentlich schon mit JSONata Filtern machbar sein
-
Und, sicher die größte Herausforderung, nur die Meldungen anzeigen, die in die gewünschte Richtung gelten.
Derzeit bekomme ich ja auch Meldungen auf der Gegenfahrbahn, die brauche ich nicht. Das müsste ja eigentlich möglich sein, es zu filtern durch "gebe nur Meldungen die Koordinate von Nord nach Süd haben".
-
-
-
Hallo,
ich habe auch mal ne Frage zu der api.Bei folgender url:
https://verkehr.autobahn.de/o/autobahn/A7/services/webcam
bekomme ich nur sowas:
Lt. api sollte doch aber eine Auflistung folgen:
Wie gesagt, ich hätte gerne das u.g. json.
Folgendes Script habe ich zum auslesen mal schnell geschrieben:
httpGet('https://verkehr.autobahn.de/o/autobahn/A7/services/webcam', { timeout: 1000 }, (error, response) => { if (!error) { console.log(response.statusCode); console.log(response.data); } else { console.error(error); } });
Im log kommt dann:
script.js.Scripte.Sonstige.Autobahn: {"webcam":[]}
Frage:
Muss die httpget anders aussehen?Die anderen url von der api funktionieren; nur halt nicht die webcam url.