<Django 对象> 不是 JSON 可序列化的
- 2025-03-18 08:54:00
- admin 原创
- 42
问题描述:
我有以下用于序列化查询集的代码:
def render_to_response(self, context, **response_kwargs):
return HttpResponse(json.simplejson.dumps(list(self.get_queryset())),
mimetype="application/json")
以下是我的get_quersety()
[{'product': <Product: hederello ()>, u'_id': u'9802', u'_source': {u'code': u'23981', u'facilities': [{u'facility': {u'name': {u'fr': u'Gxe9nxe9ral', u'en': u'General'}, u'value': {u'fr': [u'bar', u'rxe9ception ouverte 24h/24', u'chambres non-fumeurs', u'chambres familiales',.........]}]
我需要序列化它。但它说无法序列化<Product: hederello ()>
。因为列表由 django 对象和字典组成。有什么想法吗?
解决方案 1:
simplejson
并且json
不能很好地与 django 对象配合使用。
Django 的内置序列化器只能序列化填充有 django 对象的查询集:
data = serializers.serialize('json', self.get_queryset())
return HttpResponse(data, content_type="application/json")
在您的情况下,self.get_queryset()
里面包含 django 对象和字典的混合。
一个选择是摆脱模型实例self.get_queryset()
并用以下方法用字典替换它们model_to_dict
:
from django.forms.models import model_to_dict
data = self.get_queryset()
for item in data:
item['product'] = model_to_dict(item['product'])
return HttpResponse(json.simplejson.dumps(data), mimetype="application/json")
解决方案 2:
最简单的方法是使用JsonResponse。
对于查询集,您应该传递该查询集的列表values
,如下所示:
from django.http import JsonResponse
queryset = YourModel.objects.filter(some__filter="some value").values()
return JsonResponse({"models_to_return": list(queryset)})
解决方案 3:
我发现使用“ .values”方法可以相当简单地完成此操作,该方法还提供了命名字段:
result_list = list(my_queryset.values('first_named_field', 'second_named_field'))
return HttpResponse(json.dumps(result_list))
必须使用“list”来获取可迭代数据,因为“value queryset”类型只有在作为可迭代数据获取时才是字典。
文档:https://docs.djangoproject.com/en/1.7/ref/models/querysets/#values
解决方案 4:
从 1.9 版本开始获取 json 的更简单、更官方的方式
from django.http import JsonResponse
from django.forms.models import model_to_dict
return JsonResponse( model_to_dict(modelinstance) )
解决方案 5:
使用模型解决这个问题的另一种好方法是使用values()
函数。
def returnResponse(date):
response = ScheduledDate.objects.filter(date__startswith=date).values()
return Response(response)
解决方案 6:
我们的 js 程序员要求我向她返回精确的 JSON 格式数据,而不是 json 编码的字符串。
以下是解决方案。(这将返回一个可以在浏览器中直接使用/查看的对象)
import json
from xxx.models import alert
from django.core import serializers
def test(request):
alert_list = alert.objects.all()
tmpJson = serializers.serialize("json",alert_list)
tmpObj = json.loads(tmpJson)
return HttpResponse(json.dumps(tmpObj))
解决方案 7:
首先,我向模型添加了一个 to_dict 方法;
def to_dict(self):
return {"name": self.woo, "title": self.foo}
然后我有这个;
class DjangoJSONEncoder(JSONEncoder):
def default(self, obj):
if isinstance(obj, models.Model):
return obj.to_dict()
return JSONEncoder.default(self, obj)
dumps = curry(dumps, cls=DjangoJSONEncoder)
最后使用此类来序列化我的查询集。
def render_to_response(self, context, **response_kwargs):
return HttpResponse(dumps(self.get_queryset()))
这很有效
解决方案 8:
您可以将其用于 Django 模型。这里我们因为 而摆脱了包装器safe=False
,没有它就会出错。但会以多维数组的形式.values()
返回 。key->value
views.py
from django.http import JsonResponse
users = User.objects.all().values()
return JsonResponse(list(users), safe=False)
解决方案 9:
对于 Django 模型,请尝试:
users = User.objects.all()
return JsonResponse ({'data' : list(users)})
扫码咨询,免费领取项目管理大礼包!