Django:按日期范围过滤对象

Posted

技术标签:

【中文标题】Django:按日期范围过滤对象【英文标题】:Django: Filter objects by date range 【发布时间】:2014-09-04 17:42:20 【问题描述】:

我的对象模型是:

class Event(models.Model):
    start = models.DateTimeField()
    end = models.DateTimeField()

我需要过滤今天的所有对象。

我有一个对象,开始日期为 2014/03/01 00:00,结束日期为 2014/10/01 00:00。 在今天日期前过滤对象时,我需要有这个对象:

Event.objects.filter(start__gte=today, end__lte=today)

如何按今天日期过滤对象并获得 start > today

【问题讨论】:

【参考方案1】:

可以使用 datetime 模块的 combine 方法:

import datetime
today = datetime.datetime.today()
Event.objects.filter(start__gte=datetime.datetime.combine(today, datetime.time.min),
                     end__lte=datetime.datetime.combine(today, datetime.time.max))

【讨论】:

【参考方案2】:

datetime.date.today() 获取今天的日期并使用gtlt

import datetime

today = datetime.date.today()
Event.objects.filter(start__lt=today, end__gt=today)

这将过滤开始日期小于今天且结束日期大于今天的对象。

【讨论】:

以上是关于Django:按日期范围过滤对象的主要内容,如果未能解决你的问题,请参考以下文章

Django按日期范围过滤但不包括年份

Django模型对象过滤关于日期范围以查找创建对象的初始日期?

在 Django admin 中按自定义日期范围过滤

Django - 按最大(日期)年份过滤查询集

Django QuerySet 是不是使用二进制搜索按日期过滤?

Django:按计算字段过滤