Add django command to populate the database with shapefile data
This commit is contained in:
parent
b02d7d50de
commit
aa57c6e101
2 changed files with 44 additions and 0 deletions
0
backend/right_tree/api/management/__init__.py
Normal file
0
backend/right_tree/api/management/__init__.py
Normal file
44
backend/right_tree/api/management/commands/loadshapefiles.py
Normal file
44
backend/right_tree/api/management/commands/loadshapefiles.py
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
from django.core.management.base import BaseCommand
|
||||||
|
from django.contrib.gis.utils import LayerMapping
|
||||||
|
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
|
import right_tree.api.data
|
||||||
|
from right_tree.api.models import SoilLayer, EcologicalDistrictLayer
|
||||||
|
|
||||||
|
# Auto-generated `LayerMapping` dictionary for SoilLayers model
|
||||||
|
soillayer_mapping = {
|
||||||
|
'nzsc_class': 'nzsc_class',
|
||||||
|
'nzsc_group': 'nzsc_group',
|
||||||
|
'nzsc_order': {'code': 'nzsc_order'},
|
||||||
|
'shape_leng': 'SHAPE_Leng',
|
||||||
|
'geom': 'POLYGON',
|
||||||
|
}
|
||||||
|
|
||||||
|
# Auto-generated `LayerMapping` dictionary for ecologicaldistrictlayer model
|
||||||
|
ecologicaldistrictlayer_mapping = {
|
||||||
|
'ecological': 'ECOLOGICAL',
|
||||||
|
'ecologic_1': 'ECOLOGIC_1',
|
||||||
|
'ecologic_2': {'name': 'ECOLOGIC_2'},
|
||||||
|
'shape_leng': 'SHAPE_Leng',
|
||||||
|
'shape_area': 'SHAPE_Area',
|
||||||
|
'geom': 'POLYGON',
|
||||||
|
}
|
||||||
|
|
||||||
|
# Shapefiles
|
||||||
|
soillayer_shp = Path(right_tree.api.data.__file__).resolve().parent / 'resources' / 'fundamental_soil_layers' / 'fundamental-soil-layers-new-zealand-soil-classification.shp'
|
||||||
|
ecologicaldistrictlayer_shp = Path(right_tree.api.data.__file__).resolve().parent / 'resources' / 'ecological_districts' / 'DOC_EcologicalDistricts_2021_08_02.shp'
|
||||||
|
|
||||||
|
class Command(BaseCommand):
|
||||||
|
help = 'Ingests the shapefile data for ecological regions and soil layers.'
|
||||||
|
|
||||||
|
def handle(self, *args, **options):
|
||||||
|
self.stdout.write('Loading soil layers...')
|
||||||
|
soil_lm = LayerMapping(SoilLayer, soillayer_shp, soillayer_mapping, transform=False)
|
||||||
|
soil_lm.save(strict=True)
|
||||||
|
self.stdout.write(self.style.SUCCESS('Soil layers loaded succesfully.'))
|
||||||
|
|
||||||
|
self.stdout.write('Loading ecological district layers...')
|
||||||
|
ecologicaldistrictlayer_lm = LayerMapping(EcologicalDistrictLayer, ecologicaldistrictlayer_shp, ecologicaldistrictlayer_mapping, transform=False)
|
||||||
|
ecologicaldistrictlayer_lm.save(strict=True)
|
||||||
|
self.stdout.write(self.style.SUCCESS('Ecological district layers loaded succesfully.'))
|
Loading…
Reference in a new issue