ChatGPT解决这个技术问题 Extra ChatGPT

<Django 对象> 不是 JSON 可序列化的

我有以下用于序列化查询集的代码;

def render_to_response(self, context, **response_kwargs):

    return HttpResponse(json.simplejson.dumps(list(self.get_queryset())),
                        mimetype="application/json")

以下是我的get_querset()

[{'product': <Product: hederello ()>, u'_id': u'9802', u'_source': {u'code': u'23981', u'facilities': [{u'facility': {u'name': {u'fr': u'G\xe9n\xe9ral', u'en': u'General'}, u'value': {u'fr': [u'bar', u'r\xe9ception ouverte 24h/24', u'chambres non-fumeurs', u'chambres familiales',.........]}]

我需要序列化。但它说无法序列化 <Product: hederello ()>。因为列表由 django 对象和 dicts 组成。有任何想法吗 ?


c
cyph3rn3tz

simplejsonjson 不适用于 django 对象。

Django 内置的 serializers 只能序列化由 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")

希望有帮助。


现在出现错误--> 'NoneType' object has no attribute 'concrete_model' ...并使用 Django 1.4+
当模型有日期时间字段时,它不起作用。
该解决方案将触发大量查询
要直接在 JS 中使用它,只需使用 safe 标记。 stackoverflow.com/a/57939897/4157431
还有办法回去吗?此外,如果数据中有更多项目,您将覆盖解决方案中的产品
Y
YPCrumble

最简单的方法是使用 JsonResponse

对于查询集,您应该传递该查询集的 values 列表,如下所示:

from django.http import JsonResponse

queryset = YourModel.objects.filter(some__filter="some value").values()
return JsonResponse({"models_to_return": list(queryset)})

感谢 .values(),就我而言,我只需要在过滤器之后添加 .values()
D
Danny Staple

我发现使用“.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


这对我来说效果很好。尽管错误消息表明它们都在一个大列表中,但显然仍然需要 list()
Y
Yash

从版本 1.9 更容易和官方获取 json 的方式

from django.http import JsonResponse
from django.forms.models import model_to_dict


return JsonResponse(  model_to_dict(modelinstance) )

W
Woody Johnson

我们的 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))

只是HttpResponse(tmpObj)会更好
t
tuna

首先,我在模型中添加了一个 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()))

这工作得很好


D
Dr4kk0nnys

在使用模型时解决它的另一种好方法是使用 values() 函数。

def returnResponse(date):
    response = ScheduledDate.objects.filter(date__startswith=date).values()
    return Response(response)