Как включить дополнительные данные в ответ Django serializer?

StackOverflow https://stackoverflow.com/questions/413603

  •  03-07-2019
  •  | 
  •  

Вопрос

Я пытаюсь выполнить поиск в жизни с помощью Django и jQuery.Что я сделал, так это заставил javascript запросить некоторые данные с помощью функции getJSON, затем я настроил представление в Django, которое возвращает ответ JSON, автоматизированный сериализатором Django.

И это работает хорошо, оно возвращает ответ json с типом содержимого text / javascript.Чтобы избежать отправки всех данных (много таких, которые мне не нужны), я сделал это:

response.write(serializers.serialize("json", soknad_list, fields=('name', 'image', 'genre')))

Но, например, поле 'genre' - это поле ManyToMany, поэтому возможно ли получить значения, например, из genre.all.0, а не только идентификатор жанра?

И у модели есть функция get_absolute _url, возможно ли включить это в ответ JSON, если да, то как?

Итак, я предполагаю, что мой вопрос заключается в том, возможно ли включить в ответ JSON материал, отличный от необработанных полевых данных, если нет, то как бы вы решили мою проблему?

Это было полезно?

Решение 3

Я обнаружил, что самое простое - вообще не использовать сериализатор. Я не знаю, почему я не подумал об этом раньше, но я просто использовал общий список объектов, изменил mimetype на text / javascript и сделал шаблон JSON вместо HTML-шаблона.

Очень просто, и таким образом мне удалось получить все нужные данные в ответ JSON. Таким образом, вы можете добавить все, что можете добавить в HTML-шаблон в ответ JSON, даже разбивая на страницы.

Пример извлечения созданного мною представления:

<код>     возвращение object_list (запрос, queryset = object_list, template_name = 'search / results.js', template_object_name = 'result', paginate_by = 12, mimetype = 'text / javascript')

Другие советы

Сериализация JSON в Django основана на simplejson, который вы можете использовать напрямую и расширять по желанию для обработки любых объектов.Итак, здесь у вас в основном есть два варианта:либо вручную создайте список dicts с соответствующими данными и передайте его в simplejson.dumps() (который по умолчанию поддерживает строки, списки, dicts и цифры), либо напишите свой собственный кодировщик json, который знает, как сериализовать ваш конкретный набор данных.FWIW, вот (не очень хорошо протестированный, но работающий до сих пор) кодировщик json с поддержкой модели Django:

from django.utils import simplejson
from django.utils import datetime_safe
from django.utils.functional import Promise
from django.utils.translation import force_unicode
from django.utils.encoding import smart_unicode
from django.core.serializers.json import DjangoJSONEncoder

class ModelJSONEncoder(DjangoJSONEncoder):
    """
    (simplejson) DjangoJSONEncoder subclass that knows how to encode fields.

    (adated from django.serializers, which, strangely, didn't
     factor out this part of the algorithm)
    """
    def handle_field(self, obj, field):
        return smart_unicode(getattr(obj, field.name), strings_only=True)

    def handle_fk_field(self, obj, field):
        related = getattr(obj, field.name)
        if related is not None:
            if field.rel.field_name == related._meta.pk.name:
                # Related to remote object via primary key
                related = related._get_pk_val()
            else:
                # Related to remote object via other field
                related = getattr(related, field.rel.field_name)
        return smart_unicode(related, strings_only=True)

    def handle_m2m_field(self, obj, field):
        if field.creates_table:
            return [
                smart_unicode(related._get_pk_val(), strings_only=True)
                for related
                in getattr(obj, field.name).iterator()
                ]

    def handle_model(self, obj):
        dic = {}
        for field in obj._meta.local_fields:
            if field.serialize:
                if field.rel is None:
                    dic[field.name] = self.handle_field(obj, field)
                else:
                    dic[field.name] = self.handle_fk_field(obj, field)
        for field in obj._meta.many_to_many:
            if field.serialize:
                dic[field.name] = self.handle_m2m_field(obj, field)
        return dic

    def default(self, obj):
        if isinstance(o, Promise):
            return force_unicode(o)

        if isinstance(obj, Model):
            return self.handle_model(obj)

        return super(ModelJSONEncoder, self).default(obj)

HTH

Существует удобное стороннее приложение / сериализатор django, которое позволит вам включать дополнительные данные. Он также позволяет включать отношения модели и исключать список полей.

Это доступно на http://code.google.com/p/wadofstuff/wiki/DjangoFullSerializers

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top