如何在模型管理器中按字段名称过滤(NameError)

How to filter by field name in model manager (NameError)

models.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()

managers.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

尝试:

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

我认为你不能使用>=<=,所以你必须使用gtelte。您代码中的所有内容看起来都很好。所以,我怀疑 >= 是导致该错误的原因。 Refs