Skip to main content

A tool to look up UK postcode eastings, northings, and convert them to latitude and longitude.

Project description

Postcode Lookup Tool

This repository contains a simple Python package for looking up UK postcodes to obtain their easting/northing coordinates and corresponding latitude/longitude values. The package reads data from CSV files based on the postcode prefix and uses this data to perform lookups efficiently.

Features

  • Lookup eastings and northings for a given UK postcode.
  • Convert the easting and northing coordinates to latitude and longitude.
  • Efficient caching using functools.lru_cache to improve performance for repeated postcode prefix lookups.

Installation

You can install this package directly from PyPI using pip:

pip install uklookup

Usage

Command Line Usage

Once installed, you can use the package directly from the command line to look up the easting, northing, latitude, and longitude for a UK postcode:

python -m uklookup "SW1A 1AA"

Example output:

Postcode: SW1A 1AA
Easting: 530046, Northing: 179386
Latitude: 51.501009, Longitude: -0.141588

Programmatic Usage

You can also import the package and use it in your own Python scripts.

Example:

from uklookup import lookup_postcode_lat_long

postcode = "SW1A 1AA"
lat_long = lookup_postcode_lat_long(postcode)

if lat_long:
    lat, long = lat_long
    print(f"Latitude: {lat}, Longitude: {long}")
else:
    print("Postcode not found.")

Functions

lookup_postcode(postcode: str) -> Optional[Tuple[int, int]]

Looks up the easting and northing for a given UK postcode. Returns a tuple of integers (easting, northing) if found, or None if the postcode is not in the dataset.

lookup_postcode_lat_long(postcode: str) -> Optional[Tuple[float, float]]

Looks up the latitude and longitude for a given UK postcode. Returns a tuple of floats (latitude, longitude) if found, or None if the postcode is not in the dataset.

Dependencies

  • numpy
  • convertbng (for converting eastings/northings to latitudes/longitudes)

License

This project is licensed under the MIT License.

Acknowledgements

This project uses data from the Code-Point Open dataset provided by Ordnance Survey. The data is available under the Open Government Licence v3.0.

Other Projects

A much more comprehensive postcode lookup tool is available at postcodes.io. This project is a simple alternative for basic postcode lookups in an offline setting.

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

uklookup-0.0.1.tar.gz (13.9 MB view details)

Uploaded Source

Built Distribution

uklookup-0.0.1-py3-none-any.whl (13.9 MB view details)

Uploaded Python 3

File details

Details for the file uklookup-0.0.1.tar.gz.

File metadata

  • Download URL: uklookup-0.0.1.tar.gz
  • Upload date:
  • Size: 13.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for uklookup-0.0.1.tar.gz
Algorithm Hash digest
SHA256 50c72f0a8c7ce2b0881a7daf33ebd5ad990364108dead9a523e8156efc153ef0
MD5 491495b5bca0191480b1d79c40cf2e5e
BLAKE2b-256 7d446b1be64c291b3da99a81637d0ba352d5302faa955f5685227051610f8050

See more details on using hashes here.

File details

Details for the file uklookup-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: uklookup-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 13.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for uklookup-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2f570ba08c393a56995c18f6de4ea87349aa243579ef4e617e6005099c42a440
MD5 72a06056f288516226fcf0cb31f95cf5
BLAKE2b-256 39f7cf80ce94b10c048e63e57305ac316b80b4a6362c37e524b3fe72e9e780c7

See more details on using hashes here.

Supported by

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