我有以下用于序列化查询集的代码;
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组成。有任何想法吗 ?
答案 0 :(得分:85)
simplejson
和json
无法很好地使用django对象。
Django的内置serializers只能序列化充满django对象的查询集:
data = serializers.serialize('json', self.get_queryset())
return HttpResponse(data, content_type="application/json")
在你的情况下,self.get_queryset()
包含django对象和dicts的混合。
一种选择是摆脱self.get_queryset()
中的模型实例,并使用model_to_dict
替换为dicts:
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")
希望有所帮助。
答案 1 :(得分:30)
最简单的方法是使用JsonResponse。
对于查询集,您应该传递该查询集的values
列表,如下所示:
from django.http import JsonResponse
queryset = YourModel.objects.filter(some__filter="some value").values()
return JsonResponse({"models_to_return": list(queryset)})
答案 2 :(得分:16)
我发现使用“.values”方法可以很简单地完成此操作,该方法也提供了命名字段:
result_list = list(my_queryset.values('first_named_field', 'second_named_field'))
return HttpResponse(json.dumps(result_list))
“list”必须用于将数据作为可迭代的,因为“value queryset”类型只是一个dict,如果被选为可迭代的。
文档:https://docs.djangoproject.com/en/1.7/ref/models/querysets/#values
答案 3 :(得分: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()))
这很有效
答案 4 :(得分:6)
从1.9版开始 获得json更容易和官方的方式
from django.http import JsonResponse
from django.forms.models import model_to_dict
return JsonResponse( model_to_dict(modelinstance) )
答案 5 :(得分:2)
使用模型解决该问题的另一种好方法是使用values()
函数。
def returnResponse(date):
response = ScheduledDate.objects.filter(date__startswith=date).values()
return Response(response)
答案 6 :(得分:1)
我们的js程序员要求我向她返回确切的JSON格式数据,而不是返回json编码的字符串。
下面是解决方法。(分页器与此问题无关。)
objlist = Currency.objects.all()
page = request.POST.get('page', 1)
paginator = Paginator(objlist, 10)
try:
watches = paginator.page(page)
except PageNotAnInteger:
watches = paginator.page(1)
except EmptyPage:
watches = paginator.page(paginator.num_pages)
#some wired error happens if use json.dumps() directly.
JsonInfoData = serializers.serialize("json",watches);
tmp = collections.OrderedDict()
tmp['object_total'] = objlist .count()
#change the str format to json format.
tmp['data'] = json.loads(JsonInfoData)
return HttpResponse(json.dumps(tmp))