Как сериализовать в 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
Я искал, но я не нашел, где работать. Я думал о написании настраиваемого сериализатора также для списка объектов модели.
Ответы
Ответ 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')