Skip to content

katobr/django-jsonfield2

 
 

Repository files navigation

Django-JSONField2

django-json-field2 is a flexible quering JSONField and associated form field

It is a compilation and adaptation of the following projects

Feature Description

South support Form field Form widget Model field Python3 support

django-jsonfield2 is also compatible with South, Django 1.8 and Python 3.

Installation

Install from PyPI:

pip install django-jsonfield2

Source:

git clone git://github.com/DarioGT/django-jsonfield2.git

Configuration

Add jsonfield2 to your PYTHONPATH and INSTALLED_APPS setting:

INSTALLED_APPS = (
    ...
    'jsonfield2',
    ...
)

:

Usage

from django.db import models
from jsonfield2 import JSONField, JSONAwareManager

class JsonModel(models.Model):
    code = models.CharField( blank=False, null=False, max_length=20 )
    status = models.CharField( blank=True, null=True, max_length=20 )

    info = JSONField(default={})

    objects = JSONAwareManager(json_fields = ['info'])

    def __str__(self):
        return self.code

Json Query

...
obj = Person.objects.create(name = "Bill")
obj.info = {
    'sex': 'male',
    'address': {
        'country', 'Canada',
    }
}
obj.save()
Person.objects.filter(info__address__country = 'Canada')
>>> [Person: "Bill"]

Usage

Now, it will validate the JSON on entry, and store it as a text in the database. When you instantiate/fetch the object, it will be turned back into a python list/dict/string.

jsonify templatetag

This allows you to convert a python data structure into JSON within a template:

{% load jsonify %}

<script>
var foo = {{ bar|jsonify }};
</script>

Tests

python runtest.py

Todo

Allow order_by when json criteria are used

License

django-jsonfield2 is licensed under the New BSD license.

About

flexible quering JSONField and associated form field

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%