Skip to main content

A Python interface to the OpenStreetMap Overpass API

Project description

Overpass API python wrapper

Overpass API for Python.

PyPI - Version

Install it

pip install overpass

Roadmap

0.8 is the final release in the 0.8 series. It will receive bug fixes and security updates only. No new features will be added to 0.8.

We are actively working toward 1.0, which will be a significant modernization: new OverpassClient API, structured result objects, a typed query builder, richer exceptions, and a migration from requests to httpx. See the 1.0 design document for the full picture.

We would love your input. If you use this library, please read the design doc and open an issue with feedback — what works for your use case, what doesn't, and what we may have missed.

Supported Python Versions

This project is tested and supported on Python 3.10 through 3.14.

Development

Use uv for local development:

uv sync --extra dev
scripts/check

DEVELOPMENT.md contains the full contributor command reference, including live API test instructions. RELEASE.md contains the release checklist.

Migrating to 1.0

v1.0 is not released yet. Development has started and you are more than welcome to contribute! See DEVELOPMENT.md for details.

The 0.8.x line is the compatibility and deprecation path for the upcoming 1.0 release. As of version 0.8.1, the DeprecationWarning is emitted when code uses APIs that are removed or renamed in 1.0, including API, MapQuery, WayQuery, Utils.to_overpass_id, uppercase API.Get/API.Search, legacy exception names, and API.get() arguments that are replaced by the new query/result model.

See DESIGN-1.0.md for the planned 1.0 API and compatibility mapping. In particular, Utils.to_overpass_id(..., area=True) has no 1.0 replacement because Overpass API 0.7.57+ no longer supports legacy way-derived 2400xxx area IDs; query closed ways directly instead.

Usage

API() constructor

First, create an API object.

import overpass
api = overpass.API(user_agent = "Application Name (yourname@domain.ext)")

New In 0.8.2: a User-Agent must now be included for a request to the Overpass API to be accepted. For backward compatibility reasons, a default fallback User-Agent Unknown overpass-api-python-wrapper application will be sent. Please set your own applicable User-Agent for your application. If you do not, you may find your application blocked from accessing the Overpass API.

The API constructor takes several parameters, all-but-one optional:

user_agent (Required)

user_agent is required. The Overpass public servers are shared infrastructure; identifying your client is basic etiquette and helps server operators reach you if your queries are causing problems.

endpoint

The default endpoint is https://overpass-api.de/api/interpreter but you can pass in another instance:

api = overpass.API(endpoint="https://overpass.myserver/interpreter")

timeout

The default timeout is 25 seconds, but you can set it to whatever you want.

api = overpass.API(timeout=600)

debug

Setting this to True will get you debug output.

Getting data from Overpass: get()

Most users will only ever need to use the get() method. There are some convenience query methods for common queries as well, see below.

response = api.get('node["name"="Salt Lake City"]')

response will be a dictionary representing the JSON output you would get from the Overpass API directly.

Note that the Overpass query passed to get() should not contain any out or other meta statements. See verbosity below for how to control the output.

Another example:

>>> [(feature["properties"]["name"], feature["id"]) for feature in response["features"]]
[("Salt Lake City", 150935219), ("Salt Lake City", 585370637)]

You can find more examples in the examples/ directory of this repository.

The get() method takes a few parameters, all optional having sensible defaults.

verbosity

You can set the verbosity of the Overpass query out directive using the same keywords Overpass does. In order of increased verbosity: ids, skel, body, tags, meta. As is the case with the Overpass API itself, body is the default.

>>> import overpass
>>> api = overpass.API()
>>> data = api.get('way(42.819,-73.881,42.820,-73.880);(._;>;)', verbosity='geom')
>>> [f for f in data.features  if f.geometry['type'] == "LineString"]

(from a question on GIS Stackexchange)

responseformat

You can set the response type of your query using get()'s responseformat parameter to GeoJSON (geojson, the default), plain JSON (json), CSV (csv), and OSM XML (xml).

response = api.get('node["name"="Salt Lake City"]', responseformat="xml")

If you choose csv, you will need to specify which fields you want, as described here in the Overpass QL documentation. An example:

response = api.get('node["name"="Springfield"]["place"]', responseformat="csv(name,::lon,::lat)")

The response will be a list of lists:

[
    ['name', '@lon', '@lat'],
    ['Springfield', '-3.0645656', '56.2952787'],
    ['Springfield', '0.4937446', '51.7487585'],
    ['Springfield', '-2.4194716', '53.5732892'],
    ['Springfield', '25.5454526', '-33.9814866'],
    ....
]

build

We will construct a valid Overpass QL query from the parameters you set by default. This means you don't have to include 'meta' statements like [out:json], [timeout:60], [out body], etcetera. You just supply the meat of the query, the part that actually tells Overpass what to query for. If for whatever reason you want to override this and supply a full, valid Overpass QL query, you can set build to False to make the API not do any pre-processing.

date

You can query the data as it was on a given date. You can give either a standard ISO date alone (YYYY-MM-DD) or a full overpass date and time (YYYY-MM-DDTHH:MM:SSZ, i.e. 2020-04-28T00:00:00Z). You can also directly pass a date or datetime object from the datetime library.

Pre-cooked Queries: MapQuery, WayQuery

In addition to just sending your query and parse the result, overpass provides shortcuts for often used map queries. To use them, just pass them like to normal query to the API.

MapQuery

This is a shorthand for a complete ways and relations query in a bounding box (the 'map call'). You just pass the bounding box to the constructor:

MapQuery = overpass.MapQuery(50.746,7.154,50.748,7.157)
response = api.get(MapQuery)

WayQuery

This is shorthand for getting a set of ways and their child nodes that satisfy certain criteria. Pass the criteria as a Overpass QL stub to the constructor:

way_query = overpass.WayQuery('["name"="Highway 51"]')
response = api.get(way_query)

Testing

Run the default hermetic test suite with:

uv run python -W default -m pytest

Run all required local validation, matching hosted Forgejo/Codeberg CI, with:

scripts/check

Live API coverage is opt-in only and is not part of required validation:

USE_LIVE_API=true uv run python -m pytest -m live_api

FAQ

I need help or have an idea for a feature

Create a new issue.

Where did the CLI tool go?

The command line tool was deprecated in version 0.4.0.

See also

There are other python modules that do similar things.

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

overpass-0.8.2.tar.gz (58.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

overpass-0.8.2-py3-none-any.whl (17.0 kB view details)

Uploaded Python 3

File details

Details for the file overpass-0.8.2.tar.gz.

File metadata

  • Download URL: overpass-0.8.2.tar.gz
  • Upload date:
  • Size: 58.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for overpass-0.8.2.tar.gz
Algorithm Hash digest
SHA256 1d74dc7a93d2dbb32524def0a84fa142dac14f9847f576d0a9234279db21f7fd
MD5 eeb349a9110bd1f54c1d74a83ffc531a
BLAKE2b-256 e8920ccaea89e0ed77a61a2d742cdbc6d2472db044c29c8f8845fc22dcec6691

See more details on using hashes here.

File details

Details for the file overpass-0.8.2-py3-none-any.whl.

File metadata

  • Download URL: overpass-0.8.2-py3-none-any.whl
  • Upload date:
  • Size: 17.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for overpass-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7258951f41a24d4c503c41e01a0311fde282191966ed5678e30333079625e3a9
MD5 0aeb4a33401a962654d263617259491c
BLAKE2b-256 c62aa79007933490e13e308401b2e0fbee7d39b76a8a2f7bf46dfd74fff21f0c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page