Django 将数据库查出的 QuerySet 对象转换为 json 字符串

通过Django查询出MySQL数据库的数据,并将查询出的QuerySet 对象转化成 json 字符串。

写这个例子的作用主要是用来为手机端提供接口用,记录一下,以后 说不准 肯定能用到!

 

----------------  这是一条人工分界线----------------------

 

1.  假如只查询其中一条数据的对象转换为 json 字符串

例如:

row = models.User.objects.get(id=1)

直接利用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]]))

 则在转换的时候,使用方法为:

row=models.Category.objects.get(autoid=23)    
print row.toJSON()

  

---------------------   不要慌,这又是一条人工分界线   ------------------------------

 

2. 假如按条件查询出一串数据,通过上面的方式进行json操作则会报错,就要修改。

  利用 from django.core import serializers 的方法实现,关键代码:

from django.core import serializers
data = serializers.serialize("json", SomeModel.objects.all())
data1 = serializers.serialize("json", SomeModel.objects.filter(myfield1=myvalue))

 案例:

data = serializers.serialize('json', models.User.objects.filter(id=1))
print(data)

》》》 [{"model": "app01.user", "pk": 1, "fields": {"username": "wangjiawei", "password": "123456", "netname": "\u5c1a\u672a\u53d6\u540d"}}]

 

成功!!! 记录一下!  

 

********************   别翻了,我是有底线的   ****************************

 

posted @ 2018-04-15 16:24  叫我+V  阅读(3279)  评论(0编辑  收藏  举报