Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Anagraph/yogrt
https://github.com/Anagraph/yogrt
Last synced: 27 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/Anagraph/yogrt
- Owner: Anagraph
- Created: 2022-08-18T03:40:05.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-11-16T13:33:09.000Z (about 2 years ago)
- Last Synced: 2024-08-04T03:03:21.556Z (4 months ago)
- Language: Python
- Size: 9.17 MB
- Stars: 17
- Watchers: 4
- Forks: 1
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- Awesome-Geospatial - yogrt - A simple templating tool for importing GIS data to PostGIS (Database)
- jimsghstars - Anagraph/yogrt - (Python)
README
# YAML OGR Templating (yogrt) 🍦
## A simple templating tool for importing GIS data to PostGIS## Requirements
- Python 3.6+
- [GDAL & OGR](https://gdal.org/)
- [awscli](https://aws.amazon.com/cli/) (optional)
- [poetry](https://python-poetry.org/) (optional)## Installation
`poetry`:
```bash
poetry add git+ssh://[email protected]/Anagraph/yogrt.git@develop
poetry shell
```## Example
### Initialize template files
```bash
export YOGRT_TARGET_DIR=./yogrt
mkdir -p $YOGRT_TARGET_DIR
yogrt init --target-directory $YOGRT_TARGET_DIR
```You will now have the following files within the target directory:
```bash
.
├── profile.yaml
├── secrets.yaml
└── sources.yaml
```You can modify the target projection of the sources by modifying the `profile.yaml` file.
You must modify the `secrets.yaml` to configure it with your database and optionally your AWS credentials.
The `sources.yaml` file is where you will configure the sources you want to import:
```yaml
countries:
type: polygon
download_url: https://datahub.io/core/geo-countries/r/countries.geojson
table_name: countriesldc:
type: polygon
download_url: https://www.oeb.ca/documents/opendata/open-data-electricity-map-20220131.zip
table_name: ldc
is_zip: true
unzip_filename: "Electric_220131.kmz"
```### Import datasources
Run with:
```bash
yogrt run --profile=$YOGRT_TARGET_DIR/profile.yaml --sources=$YOGRT_TARGET_DIR/sources.yaml --secrets=$YOGRT_TARGET_DIR/secrets.yaml
```## Contributing
## Install for dev
```bash
git clone [email protected]:Anagraph/yogrt.git
git switch -c feature/my-new-feature
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
```## Run tests
```bash
cd tests
pytest .
```## Additional notes
You can [setup a dev PostgreSQL server](docs/postgresql-docker.md)