Skip to main content

Easy access to global administrative boundaries and geometries via Overture Maps data

Project description

wkls: Well-Known Locations

License: Apache 2.0

wkls makes it easy to find global administrative boundaries — from countries to cities — using readable, chainable Python syntax.

It fetches geometries from a mirror of Overture Maps Foundation GeoParquet data (version 2025-11-19.0) hosted on HuggingFace.

You can instantly get geometries in formats like Well-known Text (WKT), Well-known Binaries (WKB), HexWKB, GeoJSON, and SVG:

import wkls

# prints "MULTIPOLYGON (((-122.5279985 37.8155806...)))"
print(wkls.us.ca.sanfrancisco.wkt())

#prints "2025-11-19.0"
print(wkls.overture_version())

Installation

pip install wkls

This command also loads DuckDB with its related spatial extension.

Quick Start

After installing wkls, run the following commands to get started:

import wkls

# Get country geometry
usa_wkt = wkls.us.wkt()
print(f"USA geometry: {usa_wkt[:50]}...")

# Get state/region geometry
california_geojson = wkls.us.ca.geojson()

# Get city geometry
sf_svg = wkls.us.ca.sanfrancisco.svg()

# Check dataset version
print(f"Using Overture Maps data: {wkls.overture_version()}")

# Explore available data
print(f"Countries: {len(wkls.countries())}")
print(f"Dependencies: {len(wkls.dependencies())}")
print(f"US regions: {len(wkls.us.regions())}")
print(f"CA counties: {len(wkls.us.ca.counties())}")

Handling namespace collisions

Some region or locality names overlap with pandas.DataFrame attributes inherited by ChainableDataFrame (for example wkls.us.ne triggers the .ne “not equal” method rather than returning Nebraska). When a name collides with any DataFrame member or even Python keywords, use the already-supported dict-style access to force a lookup:

wkls["us"]["ne"].wkt()                # Nebraska (avoids calling DataFrame.ne)
wkls['at']['1'].regions()             # Austria's region 1

You can mix attribute and dict access freely. Prefer the bracket form whenever you suspect a collision—especially with short names, abbreviations, or words that double as python operations.

Usage

Accessing geometry

wkls supports up to 3 chained attributes:

  1. Country/Dependencies (required) – must be a 2-letter ISO 3166-1 alpha-2 code (e.g. us, de, fr)
  2. Region (optional) – must be a valid region code suffix as specified by Overture (e.g. ca for US-CA, ny for US-NY)
  3. Place (optional) – a name match against subtypes: county, locality, or neighborhood

Examples:

wkls.us.wkt()                          # country: United States
wkls.us.ca.wkt()                       # region: California
wkls.us.ca.sanfrancisco.wkt()          # city/county: San Francisco
wkls["us"]["ca"]["sanfrancisco"].wkt() # dictionary-style access

Supported formats

wkls supports the following formats:

  • .wkt() – Well-Known Text
  • .wkb() – Raw binary WKB
  • .hexwkb() – Hex-encoded WKB
  • .geojson() – GeoJSON string
  • .svg() – SVG path string

Example: Find the administrative boundary of San Francisco, California

Chained expressions like wkls.us.ca.sanfrancisco return a WKL object. Internally, this holds a Pandas DataFrame containing one or more rows that match the given chain.

        id           country    region   subtype       name     
0  085718963fffff...   US       US-CA    county    San Francisco

In most cases, wkls resolves to a single administrative boundary. But if there are name collisions (e.g., both a county and a locality called “San Francisco”), multiple rows may be returned.

By default, geometry methods like .wkt() will use the first matching row.

Helper methods

The following methods return Pandas DataFrames for easy exploration:

Method Description
wkls.countries() List all countries
wkls.dependencies() List all dependencies
wkls.us.regions() List regions in the US
wkls.us.ca.counties() List counties in California
wkls.us.ca.cities() List cities in California
wkls.subtypes() Show all distinct division subtypes

Some countries/dependencies may not have regions, so for those countries/dependencies you can directly call either .counties() or .cities(), to further explore the available data.

wkls.fk.cities()

Dataset information

You can check which version of the Overture Maps dataset is being used:

print(wkls.overture_version())
> "2025-11-19.0"

Note: The overture_version() method is only available at the root level, not on chained objects like wkls.us.overture_version().

How It Works

wkls works in two stages:

1. In-memory GERS ID resolution

Your chained attributes — up to 3 levels — are parsed in this order:

  1. country/dependency → matched by ISO 2-letter code (e.g. "us")
  2. region → matched using region code suffix as specified by Overture (e.g. "ca""US-CA")
  3. place → fuzzy-matched against names in subtypes: county, locality, or neighborhood

This resolves to a Pandas DataFrame containing one or more rows from the in-memory wkls metadata table. At this stage, no geometry is loaded yet — only metadata (like id, name, region, subtype, etc.).

2. Geometry lookup using DuckDB

The geometry lookup is triggered only when you call one of the geometry methods:

  • .wkt()
  • .wkb()
  • .hexwkb()
  • .geojson()
  • .svg()

At that point, wkls uses the previously resolved GERS ID to query the Overture division_area GeoParquet directly from S3.

The current Overture Maps dataset version can be checked with wkls.overture_version().

Contributing

We welcome contributions! Please see our Contributing Guide for details on how to get started, development setup, and submission guidelines.

License

This project is licensed under the Apache License 2.0 - see the LICENSE file for details. wkls includes, references, and leverages data from the "Divisions" theme of Overture, from Overture Maps Foundation:

Acknowledgments

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

wkls-0.4.7.tar.gz (16.3 MB view details)

Uploaded Source

Built Distribution

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

wkls-0.4.7-py3-none-any.whl (16.3 MB view details)

Uploaded Python 3

File details

Details for the file wkls-0.4.7.tar.gz.

File metadata

  • Download URL: wkls-0.4.7.tar.gz
  • Upload date:
  • Size: 16.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for wkls-0.4.7.tar.gz
Algorithm Hash digest
SHA256 88034d1ea7af2473fa3f10030064a2eb853908bc0b5fca8d8745d9cb171f4a65
MD5 338a477ed5aa2c14a0e0ff0683265d1f
BLAKE2b-256 485c1c3951be8f5fc07ee9882e977f393e6377c009a53b57efcfec90813f4ea3

See more details on using hashes here.

Provenance

The following attestation bundles were made for wkls-0.4.7.tar.gz:

Publisher: pypi-publish.yaml on wherobots/wkls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file wkls-0.4.7-py3-none-any.whl.

File metadata

  • Download URL: wkls-0.4.7-py3-none-any.whl
  • Upload date:
  • Size: 16.3 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for wkls-0.4.7-py3-none-any.whl
Algorithm Hash digest
SHA256 d71398a03141994ab197a9feb5ba597b424b05e3c56f174874ebdf5c1bf02512
MD5 621d1044d586774ad2580b030cea7bb8
BLAKE2b-256 f87f5018a68f16e7314275bf17c0567035f048a009cc1c9e70abac9a2607862a

See more details on using hashes here.

Provenance

The following attestation bundles were made for wkls-0.4.7-py3-none-any.whl:

Publisher: pypi-publish.yaml on wherobots/wkls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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