加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

如何在Django模型上定义任何一年的月份范围?

发布时间:2020-12-16 22:13:49 所属栏目:Python 来源:网络整理
导读:我有一个名为Event的Django模型,它具有事件日期的日期字段: class Event(models.Model): event_date = models.DateField() 我希望能够在模型上设置一个方法来判断事件是“春季学期”事件还是“秋季学期”事件. 春季学期定义为1月至5月.秋天是八月到十二月.

我有一个名为Event的Django模型,它具有事件日期的日期字段:

class Event(models.Model):
    event_date = models.DateField()

我希望能够在模型上设置一个方法来判断事件是“春季学期”事件还是“秋季学期”事件.

春季学期定义为1月至5月.秋天是八月到十二月.

我的目标是能够在一年的一般事件列表中按学期过滤.

我将如何编写定义每个学期的方法?

最佳答案
一种方法是:

class SpringSemesterEventManager(models.Manager):
    def get_query_set(self):
        return super(SpringSemesterEventManager,self).get_query_set() 
            .filter(is_spring_semester=True)

class FallSemesterEventManager(models.Manager):
    def get_query_set(self):
        return super(FallSemesterEventManager,self).get_query_set() 
            .filter(is_fall_semester=True)

class Event(models.Model):
    event_date = models.DateField()

    @property
    def is_spring_semester(self):
        month = self.event_date.month
        return True if month >= 1 and month <= 5 else False

    @property
    def is_fall_semester(self):
        month = self.event_date.month
        return True if month >= 8 and month <= 12 else False

    objects = models.Manager()
    spring_semester = SpringSemesterEventManager()
    fall_semester = FallSemesterEventManager()

然后在视图中你可以做到:

fall_events = Event.fall_semester.all()

希望能帮到你.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读