/leipzig-giesst-treedata

Script for retrieving and updating tree data

Primary LanguagePythonMIT LicenseMIT

Leipzig waters – weather and tree data

Prerequisites

Install & Development

Windows

QGIS

Local PostgreSQL

CREATE EXTENSION postgis;
CREATE EXTENSION postgis_topology;
  • alternatives
    • with Docker: docker run --name treedata-postgis -e POSTGRES_PASSWORD=treedata -d postgis/postgis
    • with Supabase (see below)

Miniconda

Linux

Miniconda

wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh
./Miniconda3-latest-Linux-x86_64.sh
rm ./Miniconda3-latest-Linux-x86_64.sh

MacOS

Miniconda

wget https://repo.anaconda.com/miniconda/Miniconda3-latest-MacOSX-arm64.sh
./Miniconda3-latest-MacOSX-arm64.sh
rm ./Miniconda3-latest-MacOSX-arm64.sh

All

Miniconda

  • change to folder containing this locally checked out Git repo
conda update conda
conda create -n treedata
conda activate treedata
conda install pip
  • install GDAL
conda install -c conda-forge gdal
  • support for gdalwarp
conda install -c conda-forge krb5
pip install gssapi
gdalwarp --version
  • install dependencies
pip install -r requirements.txt

Troubleshooting

  • error when executing gdalwarp --version: gdalwarp: error while loading shared libraries: libpoppler.so.126: cannot open shared object file: No such file or directory
    • solution: conda install -c conda-forge gdal libgdal tiledb=2.2
  • error while converting WFS XML to GeoJSON (e.g. city shape): fiona._err.CPLE_AppDefinedError: PROJ: internal_proj_create: no database context specified
    • solution: remove environments via unset PROJ_LIB and unset GDAL_DATA as they conflict

PyCharm

Next steps

  • copy resources/sample.env to resources/.env
    • set your (locally) PostgreSQL connection data

Local Supabase

resources/.env

PG_SERVER=localhost
PG_PORT=54322
PG_USER=postgres
PG_PASS=postgres
PG_DB=postgres
  • run supabase status in leipzig-giesst-api and add the values
SUPABASE_URL=<API URL, e.g. http://localhost:54321>
SUPABASE_BUCKET_NAME=<create new public bucket under http://localhost:54323/project/default/storage/buckets and name it e.g. "radolan_data" and use this name here>
SUPABASE_SERVICE_ROLE_KEY=<service role key)

and

MAPBOXUSERNAME=<username as displayed in https://account.mapbox.com/ under "Account" on the right upper side>
MAPBOXTOKEN=<create secret access token as described here https://docs.mapbox.com/help/tutorials/upload-curl/#getting-started>
MAPBOXTILESET=<create new tileset under https://studio.mapbox.com/tilesets/ and the copy tile set id and use it here>

(for creating tile set use dummy csv file

id,lng,lat
1,12,51

)

Demo

  • Download trees WFS file to geojson: python ./treedata/main.py trees
    • command with all options: python ./treedata/main.py trees --wfs-url <WFS-URL> --source-encoding iso-8859-1 --xml-file-name wfs --geojson-file-name trees --skip-download-wfs-xml --skip-convert-to-geojson
    • perl -pi -e s,UTF-8,ISO-8859-1,g resources/trees/wfs.xml to fix UTF-8 to ISO-8859-1
    • python ./treedata/main.py trees --source-encoding iso-8859-1 --xml-file-name wfs --geojson-file-name trees --skip-download-wfs-xml
  • Process trees: python ./treedata/main.py trees_process
    • process specific trees geojson (from resources/trees): python ./treedata/main.py trees_process --trees-geojson-file-name s_wfs_baumbestand_2023-07-23
    • command with all options: python ./treedata/main.py trees_process --city-shape-geojson-file-name city_shape --trees-geojson-file-name trees --geojson-file-name trees-transformed --database-table-name trees_tmp --skip-transform --skip-store-as-geojson --skip-upload-to-db
    • store as file only: python ./treedata/main.py trees_process --city-shape-geojson-file-name city_shape --skip-upload-to-db --trees-geojson-file-name s_wfs_baumbestand_2023-07-15
    • store in db only: python ./treedata/main.py trees_process --skip-transform --skip-store-as-geojson --trees-geojson-file-name trees_transformed --database-table-name trees_tmp
  • Process weather data (under Windows run these commands in Anaconda Prompt (miniconda3) console): python ./treedata/main.py weather
    • command with all options: python ./treedata/main.py weather --start-days-offset 2 --end-days-offset 1 --city-shape-geojson-file-name city_shape-small --city-shape-buffer-file-name city_shape-small-buffered --city-shape-buffer 2000 --city-shape-simplify 1000 --skip-buffer-city-shape --skip-download-weather-data --skip-polygonize-weather-data --skip-join-radolan-data --skip-upload-radolan-data --skip-update-tree-radolan-days --skip-upload-geojsons-to-s3 --skip-upload-csvs-to-s3 --skip-upload-mvts-to-s3 --skip-upload-geoarrow-to-s3 --skip-upload-csvs-to-mapbox
    • only join radolan shp files: python ./treedata/main.py weather --skip-download-weather-data --skip-unzip-weather-data --skip-buffer-city-shape --skip-polygonize-weather-data
    • only upload radolan geojson file: python ./treedata/main.py weather --skip-download-weather-data --skip-unzip-weather-data --skip-buffer-city-shape --skip-polygonize-weather-data --skip-join-radolan-data