swisstopo geospatial Python utilities
Project description
swisstopopy
swisstopo geospatial Python utilities.
Features
STAC API utilities
Easily filter swisstopo STAC collections based on geospatial extents, dates, file extensions or data resolutions:
import contextily as cx
import swisstopopy
region = "EPFL"
client = swisstopopy.SwissTopoClient(region)
alti3d_gdf = client.get_collection_gdf(
swisstopopy.SWISSALTI3D_COLLECTION_ID,
)
ax = alti3d_gdf.plot(alpha=0.1)
cx.add_basemap(ax, crs=alti3d_gdf.crs)
Filter to get the latest data for each tile:
latest_alti3d_gdf = swisstopopy.get_latest(alti3d_gdf)
latest_alti3d_gdf.head()
| id | collection | ... | geometry | |
|---|---|---|---|---|
| 0 | swissalti3d_2021_2532-1151 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56572 46.50684, 6.56572 46.51594, ... |
| 1 | swissalti3d_2021_2532-1151 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56572 46.50684, 6.56572 46.51594, ... |
| 2 | swissalti3d_2021_2532-1151 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56572 46.50684, 6.56572 46.51594, ... |
| 3 | swissalti3d_2021_2532-1151 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56572 46.50684, 6.56572 46.51594, ... |
| 4 | swissalti3d_2021_2532-1152 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56558 46.51584, 6.56558 46.52493, ... |
or filter by other metadata attributes such as ground resolution and/or file extensions:
alti3d_gdf[
(alti3d_gdf["assets.eo:gsd"] == 0.5)
& alti3d_gdf["assets.href"].str.endswith(".tif")
]
| id | collection | ... | geometry | |
|---|---|---|---|---|
| 0 | swissalti3d_2019_2532-1151 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56572 46.50684, 6.56572 46.51594, ... |
| 4 | swissalti3d_2019_2532-1152 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56558 46.51584, 6.56558 46.52493, ... |
| 8 | swissalti3d_2019_2533-1152 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.57861 46.51594, 6.57861 46.52503, ... |
| 12 | swissalti3d_2021_2532-1151 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56572 46.50684, 6.56572 46.51594, ... |
| 16 | swissalti3d_2021_2532-1152 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.56558 46.51584, 6.56558 46.52493, ... |
| 20 | swissalti3d_2021_2533-1152 | ch.swisstopo.swissalti3d | ... | POLYGON ((6.57861 46.51594, 6.57861 46.52503, ... |
STAC data processing
Automated generation of geospatial datasets: building footprints with estimated heights, DEM and tree canopy. For example, a tree canopy raster for any given part of Switzerland can be obtained as in:
import rasterio as rio
from rasterio import plot
dst_filepath = "tree-canopy.tif"
swisstopopy.get_tree_canopy_raster(region, dst_filepath)
with rio.open(dst_filepath) as src:
plot.show(src)
See the overview notebook and the API documentation for more details on the geospatial dataset generation functions.
Installation
Like many other geospatial Python packages, swisstopopy requires many base C libraries that cannot be installed with pip. Accordingly, the best way to install swisstopopy is to use conda/mamba, i.e., in a given conda environment, run:
# or mamba install -c conda-forge geopandas
conda install -c conda-forge geopandas
Within the same conda environment, you can then install swisstopopy using pip:
pip install swisstopopy
Note that the get_tree_canopy_raster requires PDAL and its Python bindings, which are not installed by default with swisstopopy. Like with geopandas, the easiest way to install such requirements is using conda/mamba, e.g.: conda install -c conda-forge python-pdal.
Notes
The SwissTopoClient class can be used to process any collection of the swisstopo STAC API, and basic features succh as geospatial and datetime filtering should work out of the box. However, filtering based on further metadata such as the resolution is only fully supported for the following collections:
- "ch.swisstopo.swissalti3d", namely swissALTI3D
- "ch.swisstopo.swissimage-dop10", namely SWISSIMAGE 10 cm
- "ch.swisstopo.swisssurface3d", namely swissSURFACE3D
- "ch.swisstopo.swisssurface3d-raster", namely swissSURFACE3D Raster.
Acknowledgements
- This package was created with the martibosch/cookiecutter-geopy-package project template.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swisstopopy-0.4.0.tar.gz.
File metadata
- Download URL: swisstopopy-0.4.0.tar.gz
- Upload date:
- Size: 25.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
946b38c63f2de278105ad95bcdab4498b8a83819479d37f4f700d403ea6cdb3d
|
|
| MD5 |
4a6457932efccc1992ec7b7fe2c91825
|
|
| BLAKE2b-256 |
023dadfe47994238847830c417c08c471ec990df380f456fdbac73bc962b9ca5
|
File details
Details for the file swisstopopy-0.4.0-py3-none-any.whl.
File metadata
- Download URL: swisstopopy-0.4.0-py3-none-any.whl
- Upload date:
- Size: 27.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9acfb45497d1fd418403226364f582b85f5bb4ebe0ef92d9b9cc97731d10a68a
|
|
| MD5 |
c16bbfd1544bb1e9598cf76cffe50e3a
|
|
| BLAKE2b-256 |
59b266955254a2984b450b93e1abf3b46b160acdc5072d73f799200a2208d139
|