Skip to main content

Geospatial image handling and management

Project description

landlensdb: Geospatial Image Handling and Management

Binder PyPI Docker Pulls Contributors Downloads Tests DOI

Streamlined geospatial image handling and database management

Overview

landlensdb helps you manage geolocated images and integrate them with other spatial data sources. The library supports:

  • Image downloading and storage
  • EXIF/geotag extraction
  • Road-network alignment
  • PostgreSQL integration

This workflow is designed for geo-data scientists, map enthusiasts, and anyone needing to process large sets of georeferenced images.

Features

  • GeoImageFrame Management: Download, map, and convert geolocated images into a GeoDataFrame-like structure.
  • Mapillary API Integration: Fetch and analyze images with geospatial metadata.
  • EXIF Data Processing: Extract geolocation, timestamps, and orientation from image metadata.
  • Database Operations: Store image records in PostgreSQL; retrieve them by location or time.
  • Road Network Alignment: Snap image captures to road networks for precise route mapping.

Installation

Install the latest release from PyPI:

pip install landlensdb

Dependencies

[!IMPORTANT] You MUST have both GDAL and PostgreSQL with PostGIS installed to use landlensdb.

  • See GDAL Docs for instructions on installing GDAL.
  • See PostGIS for installing PostGIS on top of PostgreSQL.

Minimum Requirements:

  • GDAL ≥ 3.5 (ensure command-line tools work, e.g., gdalinfo --version)
  • PostgreSQL ≥ 14
  • PostGIS ≥ 3.5 (the extension must be installed in your PostgreSQL database)
  • Python ≥ 3.10

Quick Start

Below is a minimal example creating a GeoImageFrame:

from landlensdb.geoclasses import GeoImageFrame
from shapely.geometry import Point

# Create a simple GeoImageFrame from scratch
geo_frame = GeoImageFrame(
	{
		"image_url": ["https://example.com/image1.jpg"],
		"name": ["SampleImage"],
		"geometry": [Point(-120.5, 35.2)]
	}
)

print(geo_frame.head())

For additional usage examples, see our documentation.

Documentation

Full documentation (including tutorials and advanced usage) is available in this repository's docs/ folder. You can build the docs locally by installing the optional [docs] extras:

pip install -e '.[docs]'
mkdocs serve

Then open http://127.0.0.1:8000/ in your browser.

Developer Guides

Local Development 1. Clone this repository. 2. Install in editable mode with dev extras: pip install --upgrade pip pip install -e .[dev] 3. Make changes as needed and contribute via Pull Requests.

Testing

We use pytest for testing. Tests requires the following test database. Create if does not exist:

createdb landlens_test && psql landlens_test -c "create extension postgis" 

Then, we can run the tests:

pytest tests

You can also run specific test files or functions, for example:

pytest tests/test_geoimageframe.py

Code Formatting & Pre-commit

landlensdb uses Black for formatting. Once you’ve installed [dev] extras:

pre-commit install
pre-commit run --all-files

This enforces linting and formatting on each commit.

Contributing

We welcome contributions! Please see CONTRIBUTING.md for guidelines on how to open issues, submit pull requests, and follow our code of conduct.

License

This project is licensed under the MIT License. See LICENSE.md for details.

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

landlensdb-0.1.4.tar.gz (35.5 kB view details)

Uploaded Source

Built Distribution

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

landlensdb-0.1.4-py3-none-any.whl (31.9 kB view details)

Uploaded Python 3

File details

Details for the file landlensdb-0.1.4.tar.gz.

File metadata

  • Download URL: landlensdb-0.1.4.tar.gz
  • Upload date:
  • Size: 35.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for landlensdb-0.1.4.tar.gz
Algorithm Hash digest
SHA256 9da713b8c62e60e2ede4d2773304543429ee0381fc370ee27bcc8af449bbced3
MD5 bca1c8ee8ce1d2e68bb7ef67130871ec
BLAKE2b-256 7c874f3be90b7e56fe69807363f0aa0e3bc7a39ba30024c966dbc6c77932a892

See more details on using hashes here.

File details

Details for the file landlensdb-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: landlensdb-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 31.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for landlensdb-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 91a9d35c118395f49bc4bff1a8995883af133f8a49139d12208a971168e66765
MD5 b5d6a15c0874951f2d2eb96be5bec9bd
BLAKE2b-256 3a3f884ace9d7e2e21b17a8780c2e3477ee3abad2e0e033c70768c0c286c3a78

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