Django-rest-framework: AttributeError: объект «OrderedDict» не имеет атрибута «pk»

Созданный на 24 мая 2015  ·  4Комментарии  ·  Источник: encode/django-rest-framework

Просмотры:

@detail_route(methods=['post'])
def quote(self, request, pk):
    task = self.get_object()

    serializer = serializers.TaskCreateQuoteSerializer(data=request.DATA, task=task)

    if not serializer.is_valid():
        return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)

    # this causes a problem
    serializer.data['servicetasks']:

сериализаторы:

class TaskCreateQuoteSerializer(serializers.Serializer):
    servicetasks = serializers.PrimaryKeyRelatedField(many=True, required=True, allow_null=False,
        queryset=ServiceTask.objects.all())

    def __init__(self, task, *args, **kwargs):
        super(TaskCreateQuoteSerializer, self).__init__(*args, **kwargs)
        # print task.servicetask_set.all()
        # self.fields['servicetasks'].queryset = task.servicetask_set.all()

Когда я пытаюсь распечатать сериализатор:

TaskCreateQuoteSerializer(data={u'servicetasks': [3115, 3114]}, task=<Task: E13/688 COMPLETE>):
    servicetasks = PrimaryKeyRelatedField(allow_null=False, many=True, queryset=[<ServiceTask: Ser...]

Поэтому всякий раз, когда я пытаюсь получить доступ к serializer.data, я получаю исключение:

AttributeError: объект «OrderedDict» не имеет атрибута «pk»

Traceback:
File "/usr/local/lib/python2.7/site-packages/django/core/handlers/base.py" in get_response
  111.                     response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/usr/local/lib/python2.7/site-packages/django/views/decorators/csrf.py" in wrapped_view
  57.         return view_func(*args, **kwargs)
File "/usr/local/lib/python2.7/site-packages/rest_framework/viewsets.py" in view
  85.             return self.dispatch(request, *args, **kwargs)
File "/usr/local/lib/python2.7/site-packages/rest_framework/views.py" in dispatch
  452.             response = self.handle_exception(exc)
File "/usr/local/lib/python2.7/site-packages/rest_framework/views.py" in dispatch
  449.             response = handler(request, *args, **kwargs)
File "/usr/src/app/abas/apps/api/views.py" in quote
  270.         if not serializer.data['servicetasks']:
File "/usr/local/lib/python2.7/site-packages/rest_framework/serializers.py" in data
  466.         ret = super(Serializer, self).data
File "/usr/local/lib/python2.7/site-packages/rest_framework/serializers.py" in data
  215.                 self._data = self.to_representation(self.validated_data)
File "/usr/local/lib/python2.7/site-packages/rest_framework/serializers.py" in to_representation
  426.                 attribute = field.get_attribute(instance)
File "/usr/local/lib/python2.7/site-packages/rest_framework/relations.py" in get_attribute
  364.         if not instance.pk:

Самый полезный комментарий

Свойство serializer.data допустимо только в том случае, если у вас есть сохраненный экземпляр для сериализатора.
Либо вызовите serializer.save() , либо используйте serializer.validated_data для доступа к данным перед сохранением.
Мы должны предусмотреть явную защиту от такого использования.

Все 4 Комментарий

Свойство serializer.data допустимо только в том случае, если у вас есть сохраненный экземпляр для сериализатора.
Либо вызовите serializer.save() , либо используйте serializer.validated_data для доступа к данным перед сохранением.
Мы должны предусмотреть явную защиту от такого использования.

Я также столкнулся с этим, используя декоратор detail_route для аналогичной цели. Потребовалось много времени, чтобы понять, что происходит. Было бы полезно, если бы существовала защита от этого, в которой говорилось бы о вашем предыдущем ответе The serializer.data property is only valid if you have a saved instance to serializer. Either call serializer.save() or use serializer.validated_data to access date prior to saving.

@tomchristie Текущая ошибка здесь возникает при доступе к data , поэтому мы не можем сказать: «Либо вызовите serializer.save(), либо используйте serializer.validated_data для доступа к дате перед сохранением». так как последнее все равно не работает в этом случае.

Отредактировано.

Вопрос: хотим ли мы, чтобы data заполнялось validated_data , если нет ошибок.
Я думаю, что мы могли бы удалить - из-за устаревания - строки 224/225 в https://github.com/tomchristie/django-rest-framework/blob/8d7c0a8474583df6b27d0d5be8a84bd9a154ab35/rest_framework/serializers.py#L224 .

Была ли эта страница полезной?
0 / 5 - 0 рейтинги