1. 程式人生 > >Django筆記(2)Json字段處理

Django筆記(2)Json字段處理

chang class float 類型 asc con keyword gen uri

1)

Django裏面讓Model用於JSON字段,添加一個JSONField自動類型如下:

[python] view plain copy
  1. class JSONField(models.TextField):
  2. __metaclass__ = models.SubfieldBase
  3. description = "Json"
  4. def to_python(self, value):
  5. v = models.TextField.to_python(self, value)
  6. try:
  7. return
    json.loads(v)[‘v‘]
  8. except:
  9. pass
  10. return v
  11. def get_prep_value(self, value):
  12. return json.dumps({‘v‘:value})


之後就直接為Model定義JSONField類型字段了

[python] view plain copy
  1. class Category(models.Model):
  2. name = fields.MedialNameField()
  3. other= fields.JSONField()

使用很方便:

[python] view plain copy
  1. Category.objects.create(name="C1", other=(1,2,3,4,5))

所有可以被json序列化的類型都可以直接賦值給other字段,很方便吧。

2)使用postgreSql作為後端時,提供JSONField字段

from django.contrib.postgres.fields import JSONField
info =JSONField("時空信息",max_length=500,default={},blank=True)

美化後臺JSON字段:

1)自定義widget

# -*- coding: utf-8 -*-

import json

from django.forms import Widget
from django.utils.safestring import mark_safe


class JsonEditorWidget(Widget):
"""
django admin 後臺中使用 jsoneditor 處理 JSONField

TODO:有待改進, 這裏使用 % 格式化,使用 format 會拋出 KeyError 異常
"""

html_template = """
<div id=‘%(name)s_editor_holder‘ style=‘padding-left:170px‘></div>
<textarea hidden readonly class="vLargeTextField" cols="40" id="id_%(name)s" name="%(name)s" rows="20">%(value)s</textarea>

<script type="text/javascript">
var element = document.getElementById(‘%(name)s_editor_holder‘);
var json_value = %(value)s;

var %(name)s_editor = new JSONEditor(element, {
onChange: function() {
var textarea = document.getElementById(‘id_%(name)s‘);
var json_changed = JSON.stringify(%(name)s_editor.get()[‘Object‘]);
textarea.value = json_changed;
}
});

%(name)s_editor.set({"Object": json_value})
%(name)s_editor.expandAll()
</script>
"""

def __init__(self, attrs=None):
super(JsonEditorWidget, self).__init__(attrs)

def render(self, name, value, attrs=None):
if isinstance(value, str):
value = json.loads(value)

result = self.html_template % {‘name‘: name, ‘value‘: json.dumps(value),}
return mark_safe(result)

2)在admin中引用


from django.contrib import admin
from django.contrib.postgres.fields import JSONField

from djtools import widget

from .models import Person,Tag# Register your models here.
class CommonAdminMixin(admin.ModelAdmin):
"""Common Admin Mixin"""
list_max_show_all = 20
list_per_page = 20

formfield_overrides = {
JSONField: {‘widget‘: widget.JsonEditorWidget}
}

class Media:
from django.conf import settings
static_url = getattr(settings, ‘STATIC_URL‘)

css = {
‘all‘: (static_url + ‘jsoneditor.min.css‘, )
}
js = (static_url + ‘jsoneditor-minimalist.min.js‘, )
#Person模型管理器
admin.site.site_header = 歷史時空管理系統
admin.site.site_title = 歷史時空




@admin.register(Person)
class PersonAdmin(CommonAdminMixin):
pass

效果:

技術分享圖片

  1. name = fields.MedialNameField()


所有可以被json序列化的類型都可以直接賦值給other字段,很方便吧。

Django筆記(2)Json字段處理