NEWS
FF-Einsätze OÖ auswerten
-
Hallo Oliver!
Ist es möglich, dies noch zu implementieren (in Alexa, Telegram und Email).
<einheiten>
<einheit id="410314">Feuerwehr/Florian Maasbach (45314)</einheit>
</einheiten>Aber nur den Namen davon.
Im Beispiel alsoFeuerwehr/Florian Maasbach
-
@negalein
Klar
Poste bitte mal deinen letzten skriptstand
Dann kann ich morgen/übermorgen mal schauen
Ist nix großes -
@oliverio sagte in FF-Einsätze OÖ auswerten:
Poste bitte mal deinen letzten skriptstand
Danke
Ah und noch was.
wie hier zu sehn, werde
Eggerding
mit den Abschnitten `Maasbach, Hof, ...) alarmiert.
Sind dann 4 Meldungen hintereinander.
Kann man in so einem Fall dies auf 1 Zusammenfassen?zB so:
Achtung
Feuerwehreinsatz in Eggerding
Alarmstufe 0
Einsatz od. Einsatzübung
Einheit Hof, Maasbach, Vollmannsdorf, Eggerding
Bezirk Schärding
Anzahl Feuerwehren 1 -
Bitte noch deinen letzten Stand vom Skript posten.
-
@negalein sagte in FF-Einsätze OÖ auswerten:
@oliverio sagte in FF-Einsätze OÖ auswerten:Poste bitte mal deinen letzten skriptstand
-
ach, der knopf, danke.
-
für die erste anforderung bitte die folgende funktion tauschen
Es erzeugt nun folgende Nachricht'Achtung;Feuerwehreinsatz in Kefermarkt;Feuerwehr/Florian Kefermarkt ;Alarmstufe 0;Einsatz od. Einsatzübung;Bezirk Freistadt;Anzahl Feuerwehren 1;
Wenn mehrere Einheiten aufgeführt werden, dann lautet die Meldung
'Achtung;Feuerwehreinsatz in Kefermarkt;Feuerwehr/Florian Einheit A Feuerwehr/Florian Einheit B Feuerwehr/Florian Einheit C;Alarmstufe 0;Einsatz od. Einsatzübung;Bezirk Freistadt;Anzahl Feuerwehren 1;
Das ist alles relativ viel Wiederholung. ggfs. könnte man das auch noch so aufbauen:
Einheiten A B C
In meinen aktuellen Daten fängt das Feld immer mit Feuerwehr/Florian an. Das könnte man noch herausfiltern. Wenn das dann aber mal anders heißt dann schlägt das ggfs fehl.
async function prepareMessages(einsaetze, kurz, alle) { let messages = []; const dateOptions = { weekday: "long", }; const timeOptions = { hour: "2-digit", minute: "2-digit" }; let data = await getStateAsync(savedEinsaetzeDP); let einsaetzeGesendet = JSON.parse(data.val || "[]"); einsaetze.map(einsatz => { if (!einsaetzeGesendet.some(el => el.id == einsatz.id) || alle) { let einheiten = einsatz.einheiten.reduce((acc, einheit) => { return acc + einheit.bezeichnung.replace(/(.+) \(\d+\)/gm, "$1") + " "; }, "") if (kurz) { messages.push(['Achtung;Feuerwehreinsatz in ', einsatz.earea, ';', einheiten, ';', 'Alarmstufe ', einsatz.alarmstufe, ';', einsatz.einsatzsubtyp, ';'].join('')); } else { messages.push(['Achtung;Feuerwehreinsatz in ', einsatz.earea, ';', einheiten, ';', 'Alarmstufe ', einsatz.alarmstufe, ';', einsatz.einsatzsubtyp, ';', 'Bezirk ', einsatz.bezirk_name, ';Anzahl Feuerwehren ', einsatz.einheiten.length, ';'].join('')); } einsaetzeGesendet.push({ id: einsatz.id, time: new Date() }); } }) await setStateAsync(savedEinsaetzeDP, JSON.stringify(einsaetzeGesendet)); return messages.join(";"); }
-
für die 2.anforderung, die Zusammenfassung ist etwas schwieriger.
Die Datenlogik sagt, das das alles einzelne Einsätze sind.
Jeder Einsatz hat die Möglichkeit 1 oder mehrere Einheiten zu benennen.
In diesem Fall wurden aber verschiedene Einsätze mit jeweils einer Feuerwehr definiert worden.Wenn ich nun eine Logik erarbeite, die unterschiedliche Einsätze evtl anhand des Namens versucht zusammenzufassen, dann kann es aber auch falsches zusammenfassen.
hier mal ein Screenshot von einem Einsatz mit mehreren Einheiten
Dein Beispiel mit Eggerding habe ich hier allerdings auch nicht gefunden
https://cf-einsaetze.ooelfv.at/einsatz/monat-0 -
@oliverio sagte in FF-Einsätze OÖ auswerten:
Dein Beispiel mit Eggerding habe ich hier allerdings auch nicht gefunden
da dürfte für meinen Bezirk etwas nicht freigeschaltet sein.
403 ERROR The request could not be satisfied. This distribution is not configured to allow the HTTP request method that was used for this request. The distribution supports only cachable requests. We can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner. If you provide content to customers through CloudFront, you can find steps to troubleshoot and help prevent this error by reviewing the CloudFront documentation. Generated by cloudfront (CloudFront) Request ID: 6gDmI6j51Qi2t3xCnv1jm4fba93dTLXgUS-uJEp-feAvBAAa0KSzhA==
Ah, verstehe.
Das lassen wir dann sein. -
@oliverio sagte in FF-Einsätze OÖ auswerten:
In meinen aktuellen Daten fängt das Feld immer mit Feuerwehr/Florian an. Das könnte man noch herausfiltern. Wenn das dann aber mal anders heißt dann schlägt das ggfs fehl.
Ja, das wäre super.
Vielleicht nurFeuerwehr
herausfiltern? -
@negalein sagte in FF-Einsätze OÖ auswerten:
@oliverio sagte in FF-Einsätze OÖ auswerten:
Dein Beispiel mit Eggerding habe ich hier allerdings auch nicht gefunden
da dürfte für meinen Bezirk etwas nicht freigeschaltet sein.
403 ERROR The request could not be satisfied. This distribution is not configured to allow the HTTP request method that was used for this request. The distribution supports only cachable requests. We can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner. If you provide content to customers through CloudFront, you can find steps to troubleshoot and help prevent this error by reviewing the CloudFront documentation. Generated by cloudfront (CloudFront) Request ID: 6gDmI6j51Qi2t3xCnv1jm4fba93dTLXgUS-uJEp-feAvBAAa0KSzhA==
Ah, verstehe.
Das lassen wir dann sein.Komisch.
Bin da ja nicht mal angemeldet und rufe aus D ab.
Oben rechts auf der Webseite kann man die verschiedenen Zeiträume abrufen. Das ist die Seite für den ganzen Oktober -
@oliverio sagte in FF-Einsätze OÖ auswerten:
Oben rechts auf der Webseite kann man die verschiedenen Zeiträume abrufen. Das ist die Seite für den ganzen Oktober
funktioniert wieder. Deren Server hatte Schluckauf
-
@negalein sagte in FF-Einsätze OÖ auswerten:
Vielleicht nur Feuerwehr herausfiltern?
So, hier bitte nochmal Funktion tauschen
async function prepareMessages(einsaetze, kurz, alle) { let messages = []; const dateOptions = { weekday: "long", }; const timeOptions = { hour: "2-digit", minute: "2-digit" }; let data = await getStateAsync(savedEinsaetzeDP); let einsaetzeGesendet = JSON.parse(data.val || "[]"); einsaetze.map(einsatz => { if (!einsaetzeGesendet.some(el => el.id == einsatz.id) || alle) { let einheiten = einsatz.einheiten.reduce((acc, einheit) => { return acc + einheit.bezeichnung.replace(/Feuerwehr\/(.+)\s\(\d+\)/gm, "$1") + " "; }, "") if (kurz) { messages.push(['Achtung;Feuerwehreinsatz in ', einsatz.earea, ';', einheiten, ';', 'Alarmstufe ', einsatz.alarmstufe, ';', einsatz.einsatzsubtyp, ';'].join('')); } else { messages.push(['Achtung;Feuerwehreinsatz in ', einsatz.earea, ';', einheiten, ';', 'Alarmstufe ', einsatz.alarmstufe, ';', einsatz.einsatzsubtyp, ';', 'Bezirk ', einsatz.bezirk_name, ';Anzahl Feuerwehren ', einsatz.einheiten.length, ';'].join('')); } einsaetzeGesendet.push({ id: einsatz.id, time: new Date() }); } }) await setStateAsync(savedEinsaetzeDP, JSON.stringify(einsaetzeGesendet)); return messages.join(";"); }
-
@oliverio sagte in FF-Einsätze OÖ auswerten:
So, hier bitte nochmal Funktion tauschen
Danke
wo muss ich bei der Formatierung den
,
eingeben, damit es so ausschaut?Achtung
Feuerwehreinsatz in Diersbach
Florian Diersbach,
Florian Oberedt
Alarmstufe 0
Bergung PKW
Bezirk Schärding
Anzahl Feuerwehren 2 -
@negalein
Zeile 12return acc + einheit.bezeichnung.replace(/Feuerwehr\/(.+)\s\(\d+\)/gm, "$1") + ", ";
-
mach mal lieber so, sonst bleibt immer ein komma am ende übrig
async function prepareMessages(einsaetze, kurz, alle) { let messages = []; const dateOptions = { weekday: "long", }; const timeOptions = { hour: "2-digit", minute: "2-digit" }; let data = await getStateAsync(savedEinsaetzeDP); let einsaetzeGesendet = JSON.parse(data.val || "[]"); einsaetze.map(einsatz => { if (!einsaetzeGesendet.some(el => el.id == einsatz.id) || alle) { let einheiten = einsatz.einheiten.map((einheit) => { return einheit.bezeichnung.replace(/Feuerwehr\/(.+)\s\(\d+\)/gm, "$1"); }).join(", "); if (kurz) { messages.push(['Achtung;Feuerwehreinsatz in ', einsatz.earea, ';', einheiten, ';', 'Alarmstufe ', einsatz.alarmstufe, ';', einsatz.einsatzsubtyp, ';'].join('')); } else { messages.push(['Achtung;Feuerwehreinsatz in ', einsatz.earea, ';', einheiten, ';', 'Alarmstufe ', einsatz.alarmstufe, ';', einsatz.einsatzsubtyp, ';', 'Bezirk ', einsatz.bezirk_name, ';Anzahl Feuerwehren ', einsatz.einheiten.length, ';'].join('')); } einsaetzeGesendet.push({ id: einsatz.id, time: new Date() }); } }) await setStateAsync(savedEinsaetzeDP, JSON.stringify(einsaetzeGesendet)); return messages.join(";"); }