czy JSON serializowalny

Mam następujący kod do serializacji queryset;

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

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

And following is my 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',.........]}]
/ Align = "left" / Ale mówi, że nie jest w stanie serializować <Product: hederello ()>. Ponieważ lista składa się zarówno z obiektów django, jak i dictów. Jakieś pomysły ?
Author: Daniel Roseman, 2013-05-28

6 answers

simplejson i json nie działają dobrze z obiektami django.

Wbudowane w Django serializery mogą serializować tylko zestawy zapytań wypełnione obiektami django:

data = serializers.serialize('json', self.get_queryset())
return HttpResponse(data, content_type="application/json")

W Twoim przypadku, self.get_queryset() zawiera mieszankę obiektów django i dictów wewnątrz.

Jedną z opcji jest pozbycie się instancji modelu w self.get_queryset() i zastąpienie ich dictami za pomocą 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")
Mam nadzieję, że to pomoże.
 77
Author: alecxe,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-06-21 11:51:26

Najprostszym sposobem jest użycie JsonResponse .

Dla queryset, należy przekazać listę values dla tego queryseta, jak tak:

from django.http import JsonResponse

queryset = YourModel.objects.filter(some__filter="some value").values()
return JsonResponse({"models_to_return": list(queryset)})
 19
Author: YPCrumble,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-12-13 20:07:30

Stwierdziłem, że można to zrobić dość prosto za pomocą".values " metoda, która również podaje nazwane pola:

result_list = list(my_queryset.values('first_named_field', 'second_named_field'))
return HttpResponse(json.dumps(result_list))

" list "musi być użyte, aby uzyskać dane jako iterowalne, ponieważ Typ" value queryset " jest tylko dict, jeśli zostanie odebrany jako iterowalny.

Dokumentacja: https://docs.djangoproject.com/en/1.7/ref/models/querysets/#values

 14
Author: Danny Staple,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2014-10-07 16:32:06

Najpierw dodałem metodę to_dict do mojego modelu;

def to_dict(self):
    return {"name": self.woo, "title": self.foo}

Więc mam to;

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)

I w końcu użyj tej klasy, aby serializować mój queryset.

def render_to_response(self, context, **response_kwargs):
    return HttpResponse(dumps(self.get_queryset()))
To działa całkiem dobrze]}
 5
Author: tunaktunak,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-05-28 12:20:07

Od wersji 1.9 Łatwiejszy i oficjalny sposób na uzyskanie json

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


return JsonResponse(  model_to_dict(modelinstance) )
 4
Author: Yash,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-10-13 17:59:52

Nasz programista js poprosił mnie o zwrócenie dokładnych danych w formacie JSON zamiast zakodowanego w json ciągu.

Poniżej znajduje się rozwiązanie.(Paginator nie ma nic wspólnego z tym pytaniem.)

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))
 0
Author: Woody Johnson,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-09-27 07:31:04