Skip to main content

Geo2Zip is a Python package that provides a fast and efficient way to find the closest US ZIP code for a given latitude and longitude. It uses a KDTree for quick nearest-neighbor lookup, making it suitable for geospatial queries.

Project description

Geo2Zip

Geo2Zip is a Python package that provides a fast and efficient way to find the closest US ZIP code for a given latitude and longitude. It uses a KDTree for quick nearest-neighbor lookup, making it suitable for geospatial queries.

Features

  • Quickly find the closest ZIP code for a given latitude and longitude.
  • Efficient spatial indexing using KDTree.
  • Easy-to-use command-line interface.

Installation

Prerequisites

  • Python 3.7 or higher
  • pip

Install the package

  1. Clone the repository:

    git clone https://github.com/jlopex/geo2zip.git
    cd geo2zip
    
  2. Install the package and its dependencies:

    pip install -e .
    
  3. Install development dependencies (for testing):

    pip install -e .[dev]
    

Usage

Command Line Interface

You can use the geo2zip command to find the closest ZIP code for a given latitude and longitude.

geo2zip <latitude> <longitude>

Example:

geo2zip 37.7749 -122.4194

This command will output the closest ZIP code to the provided coordinates.

As a Python Library

You can also use the Geo2Zip class directly in your Python code:

from geo2zip import Geo2Zip

# Initialize with the path to your data file
geo2zip = Geo2Zip('path/to/geo_zip/data/geo_zip.csv')

# Find the closest ZIP code
latitude = 37.7749
longitude = -122.4194
closest_zip = geo2zip.find_closest_zip(latitude, longitude)
print(f"The closest ZIP code to ({latitude}, {longitude}) is {closest_zip}")

Data

The dataset used for ZIP codes and their coordinates is extracted from the 2023 US Gazetteer Files. The CSV file is included in the package at geo2zip/data/geo2zip.csv.

Testing

Simple and stupid Tests are written using pytest. To run the tests, execute the following command:

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

geo2zip-0.1.0.tar.gz (378.7 kB view details)

Uploaded Source

Built Distribution

geo2zip-0.1.0-py3-none-any.whl (376.9 kB view details)

Uploaded Python 3

File details

Details for the file geo2zip-0.1.0.tar.gz.

File metadata

  • Download URL: geo2zip-0.1.0.tar.gz
  • Upload date:
  • Size: 378.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for geo2zip-0.1.0.tar.gz
Algorithm Hash digest
SHA256 9e0992f631e780d1eaa173df5fa83dc68f82e8e7a4493ffa7d861b98328244ac
MD5 f484c0d0d756cf5610a742a79e67b759
BLAKE2b-256 2ace90a66b4b12a6df0d12008ff2b04cf1b354dfe8a424af81caeb87845c0180

See more details on using hashes here.

File details

Details for the file geo2zip-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: geo2zip-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 376.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for geo2zip-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6d01511602b813572cf564ca1b883863e3c3b2736b26da5c5d60e26a43eb509d
MD5 75c3d06b81c9baada73bcbb4424fee8b
BLAKE2b-256 1e8f7c4c432da2492a37c1fd7dab67e8797ca54e4d20a78f0fcdd00a606a01f9

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