A Django application to bridge the gap between using enumerations and having fully-specified, normalized data models.
django-enummodel is a small utility application designed to help bridge the niche use case(s?) between defining enumerations for a given field (mutually exclusive options) and fully specifying non-exclusive options as instances of a fully specified model type.
In the common case, non-mututally exclusive options configured as a fully specified model (along with a fixture to store those options) can, in the best case, ‘just work’; in the worst case, it can provide mild headaches, notably when lazy translations are involved.
In the particular case of the author, the challenge was to avoid having to cope with a O(n) growth rate of fixtures to manage, coupled with the desire to avoid encountering issues of internationalization and being forced to choose a particular character set in which to store these values.
django-enummodel provides a Django Model object with which the developer may extend to provide the functionality sketched above:
LANGUAGE_CHOICES = ( (1,_(u'English')), (2,_(u'Spanish')), (3,_(u'French')), (255,_(u'other')), ) class Language(EnumModel): class EnumMeta: choices = LANGUAGE_CHOICES
Please note that that population of any model derived from EnumModel takes place after schema migration; therefore, changes to the choices basis will need to be rectified by running:
django-admin.py migrate app_name
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size django_enummodel-0.2.1-py2.py3-none-any.whl (10.0 kB)||File type Wheel||Python version py2.py3||Upload date||Hashes View|
|Filename, size django-enummodel-0.2.1.tar.gz (6.2 kB)||File type Source||Python version None||Upload date||Hashes View|
Hashes for django_enummodel-0.2.1-py2.py3-none-any.whl