django model如何转换成json?
2个回答
推荐于2016-11-03 · 知道合伙人互联网行家
关注
展开全部
直接利用python提供的json包,在django model的定义中增加一个方法toJSON,利用django model 能访问 _meta.fields 得到相关属性而得到,例子如下:
class Category(models.Model):
autoid = models.AutoField(primary_key=True)
email=models.CharField(max_length=150,blank=False)
comtype=models.CharField(max_length=20,blank=False)
catname=models.CharField(max_length=150,blank=False)
def __unicode__(self):
return '%s' % (self.catname)
def toJSON(self):
import json
return json.dumps(dict([(attr, getattr(self, attr)) for attr in [f.name for f in self._meta.fields]]))
然后用django查出数据,并转换成json,代码如下:
row=models.Category.objects.get(autoid=23)
print row.toJSON()
展开全部
python2.7 , django1.5
D:\Python\mysite>python manage.py shell
Python 2.7.8 (default, Jun 30 2014, 16:03:49) [MSC v.1500 32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> from dlog.models import *
>>> from django.core import serializers
>>> serializers.serialize('json', Article.objects.all())
'[{"pk": 1, "model": "dlog.article", "fields": {"pub_date": "2014-08-03T17:51:10Z", "title": "aa"}}, {"pk": 2, "model": "dlog.article", "fields": {"pub_date": "2014-08-03T17:53:51Z", "title": "ffff"}}]'
这个比较详细了
追问
这个解法之前看过了,你这个代码其实返回的是queryset并不是models.model,queryset可以序列化,但是models.model不可以。所以才来提问的。
追答
怎么跟你说呢,我都懒得搭理你
已经跟你说了,这个比较详细。而且把网址都给你了,估计你也没看
你这种人,就属于听不进别人劝的那种,别人说什么你都觉着自己是正确的。
class Category(models.Model):
autoid = models.AutoField(primary_key=True)
email=models.CharField(max_length=150,blank=False)
comtype=models.CharField(max_length=20,blank=False)
catname=models.CharField(max_length=150,blank=False)
def __unicode__(self):
return '%s' % (self.catname)
def toJSON(self):
import json
return json.dumps(dict([(attr, getattr(self, attr)) for attr in [f.name for f in self._meta.fields]]))
自己使用json模块,定义一个转换成json的类函数,这又不是很难的事情。
那个网址里面有两种解决方案。知道为什么没继续回答你的问题了吗?
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询