Sammlung von Files (JSON und CSV) für die Defikarte.ch und deren Partner die in Zukunft Daten beziehen möchten.
Die Daten können hier bezogen werden: data Verzeichnis
Wichtig Die Daten sind direkt aus OSM exportiert und in GeoJSON abgefüllt, danach werden die Daten in CSV konvertiert.
Sinn dieses Archivs ist es, Datenveränderungen täglich nachzuvollziehen. Stündlich wird nun automatisiert ein GeoJSON generiert und somit Datenveränderungen dokumentiert. Für weitere Verarbeitung stellen wir nun auch CSV Dateien zu Verfügung. Die Datensammlung soll stetig wachsen und so ein sauberes Archiv generieren.
Die Abfragen sind immer gleich aufgebaut, hier ein paar Beispiele. Für alle Abfragen besuche bitte die TXT Files. Die TXT Files dazu findet man in queries.
Umgebaute Queries die mit der Overpass API korrespondieren können, ein Auszug und nicht vollständig. Die untenstehenden Snippets sind als Beispiel zu betrachten.
Abfragen ausklappen
[out:json][timeout:25];
(
//Kanton Zürich
area["ISO3166-2"="CH-ZH"];
//Kanton Schwyz
area["ISO3166-2"="CH-SZ"];
//Kanton Schaffhausen
area["ISO3166-2"="CH-SH"];
//Kanton Zug
area["ISO3166-2"="CH-ZG"];
)->.searchArea;
// gather results
(
nwr["emergency"="defibrillator"](area.searchArea);
);
// print results
out body;
>;
out skel qt;[out:json][timeout:25];
// fetch area “CH-ZH” to search in
area["ISO3166-2"="CH-ZH"]->.searchArea;
// gather results
(
// query part for: “emergency=defibrillator”
node["emergency"="defibrillator"](area.searchArea);
way["emergency"="defibrillator"](area.searchArea);
relation["emergency"="defibrillator"](area.searchArea);
);
// print results
out body;
>;
out skel qt;[out:json][timeout:25];
area[name="Zürich"]["wikipedia"="de:Zürich"]->.zurich;
// gather results
(
node["emergency"="defibrillator"](area.zurich);
way["emergency"="defibrillator"](area.zurich);
relation["emergency"="defibrillator"](area.zurich);
);
// print results
out body;
>;
out skel qt;[out:json][timeout:25];
(
//Kanton St. Gallen
area["ISO3166-2"="CH-SG"];
//Kanton Glarus
area["ISO3166-2"="CH-GL"];
//Kanton Appenzell Innerhoden
area["ISO3166-2"="CH-AI"];
//Kanton Appenzell Ausserhoden
area["ISO3166-2"="CH-AR"];
)->.searchArea;
// gather results
(
nwr["emergency"="defibrillator"](area.searchArea);
);
// print results
out body;
>;
out skel qt;[out:json][timeout:25];
(
//Kanton St. Gallen
area["ISO3166-2"="CH-SG"];
//Kanton Glarus
area["ISO3166-2"="CH-GL"];
//Kanton Appenzell Innerhoden
area["ISO3166-2"="CH-AI"];
//Kanton Appenzell Ausserhoden
area["ISO3166-2"="CH-AR"];
)->.searchArea;
// gather results
(
nwr["emergency"="defibrillator"](area.searchArea);
);
// print results
out body;
>;
out skel qt;Dieses JSON wird für die Webseite Defikarte.ch benötigt.
[out:json][timeout:25];
(
//ganze Schweiz 24h Defis
area["ISO3166-1"="CH"];
)->.searchArea;
// gather results
(
nwr["emergency"="defibrillator"]["opening_hours"="24/7"](area.searchArea);
);
// print results
out body;
>;
out skel qt;Dieses JSON wird für die Webseite Defikarte.ch benötigt.
[out:json][timeout:25];
(
//ganze Schweiz
area["ISO3166-1"="CH"];
)->.searchArea;
// gather results
(
nwr["emergency"="defibrillator"]["opening_hours"!="24/7"](area.searchArea);
);
// print results
out body;
>;
out skel qt;In diesem Repository sind GitHub Actions eingerichtet, um täglich aktuelle Daten via Overpass API abzufragen und als GeoJSON abzulegen.
- Die aktuelle GeoJSON-Dateien sind im
dataVerzeichnis - Die GitHub Actions sind im
overpass.ymlWorkflow beschrieben - Der Workflow verwendet das Skript
run_queries.shum alle Queries laufen zu lassen - Jedes Overpass-Query ist in einer eigenen Datei im Verzeichnis
queriesabgelegt
Um ein neues Query hinzuzufügen, müssen folgende Schritte befolgt werden:
- Query schreiben und via http://overpass-turbo.osm.ch/ testen. ACHTUNG: es ist nur die Overpass Query Syntax unterstützt, keine Overpass Turbo Shortcuts (z.B.
{{geocodeArea:CH-ZH}}) - Query als neue Datei in
queriesVerzeichnis ablegen - Neues Query in
run_queries.shaufrufen
Um die Daten in CSV zu konvertieren wurde ein neuer Workflow eingerichtet.
- In der Datei
converter.pydie Input Datei (GeoJSON) und die Output Datei (CSV) in eine neue Zeile schreiben. - Den Workflow
convert.ymllaufen lassen
Dieses Repository enthält einen automatisierten Reporting-Mechanismus, der Änderungen an den Defi-Daten überwacht und als HTML-Mail verschickt.
-
Overpass-Update
- Der Workflow „Get data from Overpass“ aktualisiert die GeoJSON-Dateien (z.B.
defis_kt_be.geojson,defis_kt_zh.geojson) anhand eines Overpass-Queries. - Wenn sich der Inhalt einer Datei ändert, schreibt der Workflow einen neuen Commit auf den
main-Branch.
- Der Workflow „Get data from Overpass“ aktualisiert die GeoJSON-Dateien (z.B.
-
Diff-Reporting
- Für jeden Kanton gibt es einen eigenen Workflow, z.B.:
GeoJSON Diff Mail (BE)GeoJSON Diff Mail (ZH)
- Diese Workflows werden automatisch gestartet, sobald „Get data from Overpass“ erfolgreich abgeschlossen ist (
workflow_run-Trigger).
- Für jeden Kanton gibt es einen eigenen Workflow, z.B.:
-
Prüfung, ob ein Report nötig ist
- Der Reporting-Workflow checkt den aktuellen Stand von
mainaus. - Er merkt sich den zuletzt verarbeiteten Commit in einer Datei unter
.reporting/last_processed_sha_<KANTON>.txt. - Wenn der aktuelle Commit bereits verarbeitet wurde, wird der Workflow ohne Mail beendet (Anti-Spam).
- Falls der Commit neu ist, wird geprüft, ob die jeweilige GeoJSON-Datei im letzten Commit tatsächlich geändert wurde:
git diff --quiet HEAD^..HEAD -- data/json/defis_kt_<KANTON>.geojson
- Nur wenn sich die Datei geändert hat, wird ein Diff erzeugt und eine Mail versendet.
- Der Reporting-Workflow checkt den aktuellen Stand von
Die E-Mail enthält eine HTML-Tabelle mit allen Änderungen an der jeweiligen GeoJSON-Datei seit dem letzten Commit:
- Status:
neu– neue Defi-Standortegeändert– bestehende Standorte mit Änderungen in ausgewählten Attributen (z.B. Name, Adresse, Status)gelöscht– entfernte Standorte
- Name des Defis
- Adresse, falls vorhanden (
addr:street,addr:housenumber,addr:postcode,addr:city) - Koordinaten (Lon/Lat)
- Kartenlinks:
- OpenStreetMap-Link direkt auf den Node/Way/Relation (falls OSM-ID vorhanden)
- Google Maps-Link auf die Koordinaten
- Bei
geändertzusätzlich eine Liste der Feldänderungen, z.B.:status: 'unknown' → 'verified' addr:street: 'Alte Gasse' → 'Neue Gasse'

