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

这篇博客介绍了如何在Django中将从MySQL数据库查询出来的QuerySet对象转换为JSON字符串。首先展示了针对单个对象转换的方法,通过定义Model的toJSON方法利用json.dumps()。然后,对于多个对象的情况,利用django.core.serializers的serialize方法进行转换。示例代码展示了具体的操作过程。
摘要由CSDN通过智能技术生成

通过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"}}]

成功!!! 记录一下!

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值