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.
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
data
Verzeichnis - Die GitHub Actions sind im
overpass.yml
Workflow beschrieben - Der Workflow verwendet das Skript
run_queries.sh
um alle Queries laufen zu lassen - Jedes Overpass-Query ist in einer eigenen Datei im Verzeichnis
queries
abgelegt
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
queries
Verzeichnis ablegen - Neues Query in
run_queries.sh
aufrufen
Um die Daten in CSV zu konvertieren wurde ein neuer Workflow eingerichtet.
- In der Datei
converter.py
die Input Datei (GeoJSON) und die Output Datei (CSV) in eine neue Zeile schreiben. - Den Workflow
convert.yml
laufen lassen