python - Django REST 框架 : get field of related model in serializer

标签 python django django-models serialization django-rest-framework

我是 Django Rest Framework 的新手。我正在尝试获取我的 ListAPI展示我的各个领域Quiz (和相关)模型。它工作正常,除了我的 attempt_number field 。我得到了正确的查询集,但我不确定如何只获取每个查询的相关值。用户可以根据需要多次参加每个测验,我想显示每次尝试的查询集,因为分数等会有所不同。
我的模型设置如下:

class Quiz(models.Model):
    title = models.CharField(max_length=15)
    slug = models.SlugField(blank=True)
    questions_count = models.IntegerField(default=0)

class Question(models.Model):
    quiz = models.ForeignKey(Quiz, on_delete=models.CASCADE)
    label = models.CharField(max_length=1000)

class Choice(models.Model):
    question = models.ForeignKey(Question, on_delete=models.CASCADE)
    answer = models.CharField(max_length=100)
    is_correct = models.BooleanField('Correct answer', default=False)

class QuizTaker(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    quiz = models.ForeignKey(Quiz, on_delete=models.CASCADE)
    correct_answers = models.IntegerField(default=0)
    completed = models.BooleanField(default=False)
    attempt_number = models.PositiveIntegerField(default=0)
我的 ListAPI 的序列化程序如下所示:
class MyQuizListSerializer(serializers.ModelSerializer):
    attempt = serializers.SerializerMethodField()
    # etc..
    class Meta:
        model = Quiz
        fields = "__all__"

    def get_attempt(self, obj):
        try:
            quiztaker = QuizTaker.objects.filter(user=self.context['request'].user,
                quiz=obj)
            for attempt in quiztaker:
                attempt_number = attempt.attempt_number
            return attempt_number
如果我这样做,我总是得到 attempt_number 的最后一个值。 (因为循环会覆盖该值)。然后我尝试将其附加到列表中,如下所示:
a = []
for attempt in quiztaker:
    attempt_number = attempt.attempt_number
    a.append(attempt_number)
return a
但是后来我得到了每个查询的尝试列表,而不是每个查询的尝试次数。 IE。我得到以下三次(因为在这种情况下有三次尝试):
{
    "id": 4,
    "attempt": [
        1,
        2,
        3
    ]
},
但相反,我想要的是(对于尝试 2 和 3 等也是如此):
{
    "id": 4,
    "attempt": 1
},
所以我尝试这样做:
return a[attempt_number-1]
希望它会给我第 1 次尝试的索引零,第 1 次的 2 等索引。但是我仍然只得到最后一次尝试的次数(在这种情况下为 3)。我该如何解决这个问题?
我也试过只使用 IntegerField而不是 SerializerMethodField如下:
attempt = serializers.IntegerField(read_only=True, source='quiztaker.attempt_number')
但它什么也没返回。

最佳答案

如果我正确理解您,您希望将尝试列表添加到每个测验对象。

{
    "id": 4,
    "attempts": [{
        "id": 1,
        "attempt_number": 1,
    },
    {
        "id": 2,
        "attempt_number": 2,
    }...]
}
在这种情况下,您应该为 QuizTaker 设置一个单独的序列化程序。模型并序列化 SerializerMethodField 中的对象.
class QuizTakerSerializer(serializers.ModelSerializer):
    class Meta:
        model = QuizTaker
        fields = ('id', 'attempt_number')
 
class MyQuizListSerializer(serializers.ModelSerializer):
    attempts = serializers.SerializerMethodField()
    # etc..
    class Meta:
        model = Quiz
        fields = "__all__"

    def get_attempts(self, obj):
        quiztakers = QuizTaker.objects.filter(user=self.context['request'].user,quiz=obj)
        return QuizTakerSerializer(quiztakers, many=True).data
老实说,您的问题不是很清楚,这将有助于对其进行编辑并使其更清晰,从而提供您想要实现的 JSON 结构。我还怀疑您对 queryset 的预期用途不是 ORM 对象容器的实际 Django 含义。

关于python - Django REST 框架 : get field of related model in serializer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63751319/

相关文章:

django - "Unknown command syncdb"运行 "python manage.py syncdb"

带有 transaction.atomic 的 Django "Deadlock found"

django - 在 Django 1.5 自定义用户模型中使用电子邮件作为用户名字段会导致 FieldError

Python/Django 模型覆盖清理后的数据

python - 双向 LSTM 的问题

javascript - OpenCV在python和javascript之间调整了大不相同的结果

python - 打印用于登录 Python 的时间戳

python - 通过pyserial控制电脑键盘

django - 如何公开一个Docker容器访问主机数据库?

python - 为什么当 quizform.ans1 在访问动态创建的表单时工作时 getattr(quizform, 'ans1' ) 会失败?