首页 > 解决方案 > 如何在模型管理器中按字段名称过滤(NameError)

问题描述

模型.py

class StudentProfile(models.Model):
    student = models.OneToOneField(
    User, related_name='student', primary_key=True, parent_link=True, on_delete=models.CASCADE)
    membership_end = models.DateTimeField(
    verbose_name="Membership End Date", default=now, editable=False)

    objects = StudentProfileManager()

管理者.py

class StudentQuerySet(models.QuerySet):
    def get_student_chat_list(self):
        return self.filter(membership_end >= datetime.Now()).values_list('student_id', 'chat_user_sid')

class StudentProfileManager(models.Manager):
    def get_queryset(self):
        return StudentQuerySet(self.model, using=self._db)

    def get_student_chat_list(self):
        return self.get_queryset().get_student_chat_list()

这应该有一个非常简单的解释,但我不明白这里有什么问题。我收到以下错误:

NameError: name 'membership_end' is not defined

标签: djangodjango-model-field

解决方案


尝试:

return self.filter(membership_end__gte=datetime.Now()).values_list('student_id', 'chat_user_sid')

我不认为你可以使用>=or <=,所以你必须使用gteor lte。您的代码中的所有内容看起来都很好。所以,我怀疑>=是导致该错误。参考文献


推荐阅读