Overpass API: Unterschied zwischen den Versionen
Stefan (Diskussion | Beiträge) K (→Flaechen) |
Stefan (Diskussion | Beiträge) K (→Verschiedene) |
||
Zeile 63: | Zeile 63: | ||
</union> | </union> | ||
<print/> | <print/> | ||
+ | </osm-script> | ||
+ | |||
+ | POIs: | ||
+ | <!-- | ||
+ | This query looks for nodes, ways and relations | ||
+ | with the given key/value combination. | ||
+ | Choose your region and hit the Run button above! | ||
+ | --> | ||
+ | {{key=payment:bitcoin}} | ||
+ | {{value=yes}} | ||
+ | <osm-script output="json"> | ||
+ | <union> | ||
+ | <query type="node"> | ||
+ | <has-kv k="{{key}}" v="{{value}}"/> | ||
+ | <has-kv k="shop" modv="not" regv="."/> | ||
+ | <has-kv k="amenity" modv="not" regv="."/> | ||
+ | <has-kv k="office" modv="not" regv="."/> | ||
+ | <bbox-query {{bbox}}/> | ||
+ | </query> | ||
+ | <query type="way"> | ||
+ | <has-kv k="{{key}}" v="{{value}}"/> | ||
+ | <has-kv k="shop" modv="not" regv="."/> | ||
+ | <has-kv k="amenity" modv="not" regv="."/> | ||
+ | <has-kv k="office" modv="not" regv="."/> | ||
+ | <bbox-query {{bbox}}/> | ||
+ | </query> | ||
+ | <query type="relation"> | ||
+ | <has-kv k="{{key}}" v="{{value}}"/> | ||
+ | <has-kv k="shop" modv="not" regv="."/> | ||
+ | <has-kv k="amenity" modv="not" regv="."/> | ||
+ | <has-kv k="office" modv="not" regv="."/> | ||
+ | <bbox-query {{bbox}}/> | ||
+ | </query> | ||
+ | </union> | ||
+ | <print mode="body"/> | ||
+ | <recurse type="down"/> | ||
+ | <print mode="skeleton"/> | ||
</osm-script> | </osm-script> | ||
Version vom 4. Dezember 2013, 02:36 Uhr
Overpass API - Selektiver Download von Daten aus der Hauptdatenbank von OpenStreetMap.
Siehe auch HowTo OpenStreetMap
Webseiten:
- Overpass API (Dokumentation und öff. Server): http://overpass-api.de/ und http://wiki.openstreetmap.org/wiki/Overpass_API
- Overpass Turbo (Webapp/Server): http://overpass-turbo.eu/
Inhaltsverzeichnis
Beispiele
Verschiedene
- "Rollstuhlparkplätze der Schweiz"
- siehe Nutzen von OpenStreetMap-Daten in GIS.
- Pizzerias der Schweiz
PostGIS-Terminal (Schweiz):
SELECT ST_AsText(way) geom, name AS label FROM osm_poia WHERE tags @> hstore('cuisine', 'pizza')
Overpass Query aller Pizzerias der Schweiz (mit BBox):
<osm-script> <union> <query type="node"> <has-kv k="cuisine" v="pizza"/> <bbox-query e="10.5194091796875" n="47.92738566360356" s="45.45627757127799" w="5.69091796875"/> </query> <query type="way"> <has-kv k="cuisine" v="pizza"/> <bbox-query e="10.5194091796875" n="47.92738566360356" s="45.45627757127799" w="5.69091796875"/> </query> <recurse type="way-node"/> </union> <print/> </osm-script>
Overpass Query aller Pizzerias der Schweiz (mit effektiven Grenzen):
<osm-script output="json"> <union> <query type="area"> <has-kv k="boundary" v="administrative"/> <has-kv k="admin_level" v="2"/> <has-kv k="name:en" v="Switzerland"/> </query> <query type="node"> <area-query/> <has-kv k="cuisine" v="pizza"/> </query> <query type="area"> <has-kv k="boundary" v="administrative"/> <has-kv k="admin_level" v="2"/> <has-kv k="name:en" v="Switzerland"/> </query> <query type="way"> <area-query/> <has-kv k="cuisine" v="pizza"/> </query> <recurse type="way-node"/> </union> <print/> </osm-script>
POIs:
Vorlage:Key=payment:bitcoin Vorlage:Value=yes <osm-script output="json"> <union> <query type="node"> <has-kv k="Vorlage:Key" v="Vorlage:Value"/> <has-kv k="shop" modv="not" regv="."/> <has-kv k="amenity" modv="not" regv="."/> <has-kv k="office" modv="not" regv="."/> <bbox-query Vorlage:Bbox/> </query> <query type="way"> <has-kv k="Vorlage:Key" v="Vorlage:Value"/> <has-kv k="shop" modv="not" regv="."/> <has-kv k="amenity" modv="not" regv="."/> <has-kv k="office" modv="not" regv="."/> <bbox-query Vorlage:Bbox/> </query> <query type="relation"> <has-kv k="Vorlage:Key" v="Vorlage:Value"/> <has-kv k="shop" modv="not" regv="."/> <has-kv k="amenity" modv="not" regv="."/> <has-kv k="office" modv="not" regv="."/> <bbox-query Vorlage:Bbox/> </query> </union> <print mode="body"/> <recurse type="down"/> <print mode="skeleton"/> </osm-script>
Beispiel Eisenbahnschienen
Eisenbahnschienen (inkl. Schmalspur) in der Gegend von Rapperswil.
Diskussion:
- Die BBox-Werte für Osten müssen größer sein als für Westen und genauso die Werte für Norden größer als für Süden. Also: s<n und w<e, sortiert als s,w,n,e (Rapperswil: 47.213,8.704,47.336,8.905).
- '{{bbox}}' ist eine Variable im Overpass Turbo (funktioniert im Overpass Service natürlich nicht).
- 'recurse' löst Referenzen von Ways zu Nodes auf (warum auch immer 'recurse' (und nicht z.B. dereference) da dies ja nur einstufig ist?)
- 'union' fasst Ergebnismengen von Anfragen zusammen - auch wenn's im Falle von recurse nur eine ist (...?) (OR-Verknüpfung)
- 'print' gibt die Sache aus (warum auch immer print gewählt wurde, da dies ja nichts mit der Konsole zu tun hat... Warum nicht 'format='?)
XML:
<osm-script timeout="900"> <union> <query type="way"> <has-kv k="railway" v="rail"/> <bbox-query {{bbox}}/> </query> <recurse type="way-node"/> <query type="way"> <has-kv k="railway" v="narrow_gauge"/> <bbox-query {{bbox}}/> </query> <recurse type="way-node"/> </union> <print/> </osm-script>
QL:
[timeout:900]; ( way ["railway"="rail"] (47.213,8.704,47.336,8.905); node(w); ); out;
Kompakte QL:
- http://www.overpass-api.de/api/interpreter?data=(way["railway"="rail"](47.213,8.704,47.336,8.905);node(w););out;
- http://www.overpass-api.de/api/interpreter?data=(way%5B%22railway%22%3D%22rail%22%5D(47.213%2C8.704%2C47.336%2C8.905)%3Bnode(w)%3B)%3Bout%3B%0A
Alternative: XML mit Regex:
<osm-script timeout="900"> <union> <query type="way"> <has-kv k="railway" regv="^(rail|narrow_gauge)$"/> <bbox-query s="47.213" w="8.704" n="47.336" e="8.905"/> </query> <recurse type="way-node"/> </union> <print/> </osm-script>
XML mit Negation und Regex:
<osm-script timeout="900"> <union> <query type="way"> <has-kv k="railway" modv="not" regv="rail|narrow_gauge"/> <bbox-query s="47.213" w="8.704" n="47.336" e="8.905"/> </query> <recurse type="way-node"/> </union> <print/> </osm-script>
Flaechen
Gegeben Id-Relation, gesucht Fläche:
Step 1: First, goto www.osm.org and look for the id and/or the exact name the area (= multipolygon).
Step 2: Do this query given a relaton with the given id 2135966. It works also type=node, type=way. Choose your region and hit the Run button above!
http://overpass-turbo.eu/?template=type-id&type=relation&id=2135966&R
{{type=relation}} {{id=2135966}} <osm-script output="json"> <id-query type="{{type}}" ref="{{id}}"/> <print mode="meta"/><!-- fixed by auto repair --> <recurse type="down"/> <print mode="meta"/><!-- fixed by auto repair --> </osm-script>
Step 3: Given the GeoJSON output (see output="json"), convert it e.g. with an Online Geoconverter like OSM2KML.