A library for generating OpenStreetMap's Overpass QL queries from Python objects.
Project description
Overpass Forge: a query builder for the Overpass query language
An object-oriented model to build Overpass queries in Python. Primarly intended to generate complex queries in Python.
Install
Requires Python 3.10 or higher. Install with:
pip install overpassforge
Example
from overpassforge import Areas, Nodes, Ways, build, beautify
# Find both cinema nodes and ways in Bonn, which
# are at most 100m away from bus stop nodes
bus_stops = Nodes(within=Areas(name="Bonn"), highway="bus_stop")
ways = Ways(around=(bus_stops, 100.0)).where(amenity="cinema")
nodes = Nodes(around=(bus_stops, 100.0)).where(amenity="cinema")
result = ways + nodes
result.out("meta")
query = build(result)
print(beautify(query))
Output:
area["name"="Bonn"]->.set_0;
node(area.set_0)["highway"="bus_stop"]->.set_1;
(
way(around.set_1:100.0)["amenity"="cinema"];
node(around.set_1:100.0)["amenity"="cinema"];
);
out meta;
Features
List of currently implemented features, based on the Overpass QL wiki.
- Settings: all except augmented-difference between dates (adiff)
- Block statements
- union, difference, intersection
- For-each loop (foreach)
- Block statements if, for, complete, retro, compare
- Standalone statements
- out
- Item (implicit)
- Recurse up (<) and down (>)
- Recurse up relations (<<) and down (>>)
- Query for areas (is_in)
- Statements timeline, local, convert, make
- The Query Statement (node, way, rel, area only)
- The Query Filter
- Filters
- By tag (has-kv)
- Bounding box
- Recurse (n, w, r, bn, bw, br)
- Recurse (way_cnt, way_link)
- By input set (.setname)
- By element id
- Relative to other elements (around)
- By polygon (poly)
- newer
- By date of change (changed)
- By user (user, uid)
- By area (area)
- Area pivot (pivot)
- Conditional query filter (if:)
Contributing
Setup the development environment
Windows
python -m venv .venv
.\.venv\Scripts\Activate.ps1
python -m pip install -r requirements.txt
Linux
python -m venv .venv
source .venv/bin/activate
python -m pip install -r requirements.txt
Unit tests
Run all the tests with:
python -m pytest ./tests
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
overpassforge-0.2.0.tar.gz
(26.8 kB
view details)
Built Distribution
File details
Details for the file overpassforge-0.2.0.tar.gz
.
File metadata
- Download URL: overpassforge-0.2.0.tar.gz
- Upload date:
- Size: 26.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 356fec0a8d0ab73ef6c93ddcb1d835067ad2e19a646edd1555b8058500827ead |
|
MD5 | 52ee9d3e9136f6b2bf228f99cfcb54ed |
|
BLAKE2b-256 | a003ff779ddd4c80046adc0c869d214531a6f8a629d47d905e64cf39e03cad02 |
File details
Details for the file overpassforge-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: overpassforge-0.2.0-py3-none-any.whl
- Upload date:
- Size: 16.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e3c51ea53a8278f287dbf27d7de7238b79a94bf607bec5dc652b974f5b93afbb |
|
MD5 | 07916bb2576df727ccf153376a37faab |
|
BLAKE2b-256 | 0f25bbdb4ce905487fc4cfa74262bffb736ac4f88d7294524119dd5a70488d84 |