не сериализуем в JSON
у меня есть следующий код для сериализации queryset;
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'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 и диктов. Есть идеи ?
6 ответов:
simplejsonиjsonне работают с объектами 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")надеюсь, что это поможет.
самый простой способ-это использовать JsonResponse.
для queryset, вы должны передать список the
valuesдля этого queryset, вот так:from django.http import JsonResponse queryset = YourModel.objects.filter(some__filter="some value").values() return JsonResponse({"models_to_return": list(queryset)})
Я нашел, что это можно сделать довольно просто с помощью ".значения " метод, который также дает именованные поля:
result_list = list(my_queryset.values('first_named_field', 'second_named_field')) return HttpResponse(json.dumps(result_list))" список "должен использоваться для получения данных как iterable, так как тип" value queryset " является только dict, если он выбран как iterable.
документация:https://docs.djangoproject.com/en/1.7/ref/models/querysets/#values
сначала я добавил метод 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()))это работает довольно хорошо
С версии 1.9 Более простой и официальный способ получения json
from django.http import JsonResponse from django.forms.models import model_to_dict return JsonResponse( model_to_dict(modelinstance) )
наш 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))
Comments