Python <;Django对象>;JSON不可序列化

Python <;Django对象>;JSON不可序列化,python,django,json,serialization,django-class-based-views,Python,Django,Json,Serialization,Django Class Based Views,我有以下用于序列化queryset的代码 def render_to_response(self, context, **response_kwargs): return HttpResponse(json.simplejson.dumps(list(self.get_queryset())), mimetype="application/json") 下面是我的get\u queryset() 我需要序列化。但是它说不能序列化。因

我有以下用于序列化queryset的代码

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

    return HttpResponse(json.simplejson.dumps(list(self.get_queryset())),
                        mimetype="application/json")
下面是我的
get\u queryset()



我需要序列化。但是它说不能序列化
。因为列表由django对象和dict组成。有什么想法吗?

simplejson
json
不能很好地处理django对象

Django的内置只能序列化由Django对象填充的QuerySet:

data = serializers.serialize('json', self.get_queryset())
return HttpResponse(data, content_type="application/json")
在您的例子中,
self.get\u queryset()
包含django对象和dict的混合体

一种选择是在
self.get\u queryset()
中删除模型实例,并使用
model\u to\u dict
将它们替换为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")

希望能有所帮助。

首先,我在模型中添加了一个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)
最后使用这个类来序列化我的queryset

def render_to_response(self, context, **response_kwargs):
    return HttpResponse(dumps(self.get_queryset()))

这非常有效

我发现使用“.values”方法可以非常简单地完成,该方法还提供命名字段:

result_list = list(my_queryset.values('first_named_field', 'second_named_field'))
return HttpResponse(json.dumps(result_list))
必须使用“list”将数据作为iterable获取,因为“value queryset”类型仅在作为iterable获取时是dict

文档:

来自1.9版 获取json的更简单、更正式的方法

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


return JsonResponse(  model_to_dict(modelinstance) )

最简单的方法是使用一个

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

from django.http import JsonResponse

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

我们的js程序员让我向她返回确切的JSON格式数据,而不是JSON编码的字符串

下面是解决方案。(这将返回一个可以在浏览器中直接使用/查看的对象)


在使用模型时,另一个解决此问题的好方法是使用
values()
函数

def返回响应(日期):
response=ScheduledDate.objects.filter(date\u startswith=date).values()
返回响应(响应)

现在出现错误-->
'NoneType'对象没有属性'concrete_model'
…并且使用Django 1.4+当模型有datetime字段时,它不起作用。该解决方案将触发大量查询要直接在JS中使用它,只需使用
安全
阶段。这对我来说效果很好。尽管错误消息表明它是在一个大列表中,显然仍然需要
list()
。最简单和最好的解决方案重复:这能回答您的问题吗?感谢.values(),在我的情况下,我只需要在过滤器之后添加.values(),这样会更好
HttpResponse(tmpObj)
from django.http import JsonResponse

queryset = YourModel.objects.filter(some__filter="some value").values()
return JsonResponse({"models_to_return": list(queryset)})
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))