Skip to content
This repository has been archived by the owner on May 2, 2021. It is now read-only.

Django shape-engine is a simple implementation that will allow you to export django querysets to shapefiles.

Notifications You must be signed in to change notification settings

sigma-geosistemas/django-shape-engine

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

django-shape-engine

Django shape-engine is a simple implementation that will allow you to export django querysets to shapefiles.

The shape-engine currently supports three different backends:

  • Fiona (recommended);
  • Native;
  • CTypes;

The only one tested is the Fiona backend.

This code is all based on Dane Springmeyer (@springmeyer) django-shapes and Luiz Fernando Vital (@luizvital) Fiona implementation.

The original code (https://bitbucket.org/springmeyer/django-shapes/wiki/Home) exported everything to a single data-type: strings. This code can look into the field type and guess what data type it needs to have in the shapefile.

The only caveat is that the support for properties the original project had is missing.

This is very very alpha stage, but the Fiona implementation works.

If there are bugs (I'm pretty sure some will appear :)), please let me know.

Export dictionary

If you need to support custom fields, you can alter the dictionaries that will be used to map the field types.

Basically, the field map for Fiona is:

    ENGINE_FIONA_MAPPING = { CharField: "str",
                             TextField: "str",
                             NullBooleanField: "str",
                             BooleanField: "str",
                             URLField: "str",
                             ImageField: "str",
                             ForeignKey: "str",
                             OneToOneField: "str",
                             EmailField: "str",
                             FileField: "str",
                             SlugField: "str",
                             AutoField: "int",
                             SmallIntegerField: "int",
                             PositiveIntegerField: "int",
                             IntegerField: "int",
                             BigIntegerField: "int",

                             DecimalField: "float",
                             FloatField: "float",

                             DateField: "str",
                             TimeField: "str",
                             DateTimeField: "str"}

Usage

To write shapefiles you can use the ShapefileWriter factory class.

Just do:

    shp_writer = ShapefileWriter.create(engine=ENGINE_FIONA)
    # django queryset, "list of field names to be exported", "string with name of geofield", "string with output filename", "output projection"
    shp_writer.write_records(queryset, self.get_attributes(), geofield, tmp_name, self.proj_transform)

To return zipped shapefiles from a queryset, use the shaperesponder view.

About

Django shape-engine is a simple implementation that will allow you to export django querysets to shapefiles.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •