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

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

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

 

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

 

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

例如:

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

直接利用python提供的json包,在django model的定义中增加一个方法toJSON,利用django model 能访问 _meta.fields 得到相关属性而得到,例子如下:

1
2
3
4
5
6
7
8
9
10
11
12
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]]))

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

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

  

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

 

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

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

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

 案例:

1
2
data = serializers.serialize('json', models.User.objects.filter(id=1))
print(data)<br><br>》》》  [{"model": "app01.user", "pk": 1, "fields": {"username": "wangjiawei", "password": "123456", "netname": "\u5c1a\u672a\u53d6\u540d"}}]

 

成功!!! 记录一下!  

 

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

 

posted @   叫我+V  阅读(3290)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示