Подтвердить что ты не робот

Как сериализовать в JSON список объектов модели в django/python

Я пытаюсь выполнить сериализацию списка объекта модели, определенного как:

class AnalysisInput(models.Model):
    input_user = models.CharField(max_length=45)
    input_title = models.CharField(max_length=45)
    input_date = models.DateTimeField()
    input_link = models.CharField(max_length=100)

Я написал собственный сериализатор (кодировщик) для json.dumps():

class AnalysisInputEncoder(json.JSONEncoder):
    def default(self, obj):
        if isinstance(obj, AnalysisInput):
            return { "input_id" : obj.id,
                    "input_user" : obj.input_user,
                    "input_title" : obj.input_title,
                    "input_date" : obj.input_date.isoformat(),
                    "input_link" : obj.input_link }
        return json.JSONEncoder.default(self, obj)

Когда я сериализую только один объект, я могу это сделать. Когда я пытаюсь сериализовать список объектов, я получаю

[ objects..] is not JSON serializable

Я искал, но я не нашел, где работать. Я думал о написании настраиваемого сериализатора также для списка объектов модели.

4b9b3361

Ответ 1

Пользовательский кодер не называется рекурсивно. На самом деле вам лучше не использовать собственный кодировщик и вместо этого преобразовать объекты в простые типы python.

Вы можете добавить к своей модели метод as_json или аналогичного имени и вызвать его каждый раз, когда вам нужен результат JSON:

class AnalysisInput(models.Model):
    input_user = models.CharField(max_length=45)
    input_title = models.CharField(max_length=45)
    input_date = models.DateTimeField()
    input_link = models.CharField(max_length=100)

    def as_json(self):
        return dict(
            input_id=self.id, input_user=self.input_user,
            input_title=self.input_title, 
            input_date=self.input_date.isoformat(),
            input_link=self.input_link)

Тогда, на ваш взгляд:

# one result
return HttpResponse(json.dumps(result.as_json()), content_type="application/json")

# a list of results
results = [ob.as_json() for ob in resultset]
return HttpResponse(json.dumps(results), content_type="application/json")

Ответ 2

Лучший способ, которым я нашел сериализацию ваших моделей Django, - это использовать django.core.serializers для сериализации вашего списка моделей в JSON, XML или YAML. Не требуется никакого кода сериализации! Документация находится здесь: https://docs.djangoproject.com/en/dev/topics/serialization/

Вот моя реализация:

опережение/models.py:

from django.db import models

class Lead(models.Model):
    name = models.CharField(max_length=50)
    email = models.CharField(max_length=256)
    phone = models.CharField(max_length=20)
    twitter_handle = models.CharField(max_length=20)
    github_handle = models.CharField(max_length=20)

опережение/views.py:

from django.http import HttpResponse
from django.core import serializers
from lead.models import Lead

def index(request):
    leads_as_json = serializers.serialize('json', Lead.objects.all())
    return HttpResponse(leads_as_json, content_type='json')

Конечный результат:

[{"pk": 1, "model": "lead.lead", "fields": {"twitter_handle": "johndoe", "name": "John Doe", "phone": "1(234)567-8910", "email": "[email protected]", "github_handle": "johndoe"}}]

Ответ 3

Самое простое решение:

def index(request):
    data = serializers.serialize('json', Product.objects.all())
    return HttpResponse(data, content_type='application/json')