Python implementation of geographical tiling using QuadKeys as proposed by Microsoft
Project description
🌍 pyquadkey2
This is a feature-rich Python implementation of QuadKeys, an approach to geographical tiling, popularized by Microsoft to be used for Bing Maps.
In essence, the concept is to recursively divide the flat, two-dimensional world map into squares. Each square contains four squares as children, which again contain four squares and so on, up centimeter-level precision. Each of these squares is uniquely identifiable with a string like 021030032
.
For more details on the concept, please refer to the original article.
muety/pyquadkey2 originates from a fork of buckhx/QuadKey, which is not maintained anymore. It builds on top of that project and adds:
- ✅ Several (critical) bug fixes
- ✅ Python 3 support
- ✅ Type hints for all methods
- ✅ Higher test coverage
- ✅ Cython backend for improved performance
- ✅ 64-bit integer representation of QuadKeys
- ✅ Additional features and convenience methods
Installation
Requirements
This library requires Python 3.10 or higher. To compile it from source, Cython is required in addition.
Using Pip
$ pip install pyquadkey2
Pip installation is only tested for Linux and Mac, yet. If you encounter problems with the installation on Windows, please report them as a new issue.
From archive
$ wget https://github.com/muety/pyquadkey2/releases/download/0.3.1/pyquadkey2-0.3.1.tar.gz
$ pip install pyquadkey2-0.3.1.tar.gz
From source
Prerequisites (Linux
)
gcc
- Fedora:
dnf install @development-tools
- Ubuntu / Debian:
apt install build-essential
- Fedora:
python3-devel
- Fedora:
dnf install python3-devel
- Ubuntu / Debian:
apt install python3-dev
- Others: See here
- Fedora:
Prerequisites (Windows
)
- Visual C++ Build Tools 2015 (with Windows 10 SDK) (see here)
Build
# Check out repo
$ git clone https://github.com/muety/pyquadkey2
# Create and active virtual environment (optional)
$ python -m venv ./venv
$ source venv/bin/activate
# Install depencencies
$ pip install -r requirements.txt
# Compile
$ cd src/pyquadkey2/quadkey/tilesystem && python setup.py build_ext --inplace && cd ../../../..
# Install as module
$ pip install .
Developer Notes
Unit Tests
python tests/__init__.py
Release
See here.
pip install setuptools wheel auditwheel
python -m build
cd dist
auditwheel repair *.whl
twine upload --repository testpypi wheelhouse/* ../*.tar.gz
License
Apache 2.0
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
Built Distribution
File details
Details for the file pyquadkey2-0.3.1.tar.gz
.
File metadata
- Download URL: pyquadkey2-0.3.1.tar.gz
- Upload date:
- Size: 69.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 587ffa758c37857ac14d67aaed6f2473911bc194b74d1713a577b97413ec4264 |
|
MD5 | 3890a46fee6c3a5e429198abea155a1a |
|
BLAKE2b-256 | aa327cf240304eaff8c5af857cefafd2e87eb65ffb4e9b845d44ade68e413fc3 |
File details
Details for the file pyquadkey2-0.3.1-cp311-cp311-manylinux_2_5_x86_64.manylinux1_x86_64.whl
.
File metadata
- Download URL: pyquadkey2-0.3.1-cp311-cp311-manylinux_2_5_x86_64.manylinux1_x86_64.whl
- Upload date:
- Size: 46.7 kB
- Tags: CPython 3.11, manylinux: glibc 2.5+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 91a7097a3c3e67cc59f0e99aafc4237f4775f07ded445c3d75bfd42889c5c7fd |
|
MD5 | 9677918172ba9d06287bac6ea1965f32 |
|
BLAKE2b-256 | d046b68fc97deb65acc834cdb30c1b5282c8765e6ddf7e3cb88933061344beab |