我试图过滤一个DateTimeField与日期比较。我的意思是:

MyObject.objects.filter(datetime_attr=datetime.date(2009,8,22))

我得到一个空的查询集列表作为答案,因为(我认为)我没有考虑时间,但我想要“任何时间”。

Django中有简单的方法来做这个吗?

我在datetime中设置了时间,不是00:00。


当前回答

很简单,如果你有一个datetimefield你可以使用datetime。date。today()

context['now'] = Mymodel.objects.filter(date_time_field=datetime.date.today())

其他回答

Mymodel.objects.filter(date_time_field__contains=datetime.date(1986, 7, 28))

以上就是我所使用的。它不仅有效,而且有一些内在的逻辑支持。

YourModel.objects.filter(datetime_published__year='2008', 
                         datetime_published__month='03', 
                         datetime_published__day='27')

//在注释后编辑

YourModel.objects.filter(datetime_published=datetime(2008, 03, 27))

不工作,因为它创建了一个时间值设置为0的datetime对象,因此数据库中的时间不匹配。

假设active_on是一个日期对象,将其增加1天,然后执行range

next_day = active_on + datetime.timedelta(1)
queryset = queryset.filter(date_created__range=(active_on, next_day) )
MyObject.objects.filter(datetime_attr__date=datetime.date(2009,8,22))
person = Profile.objects.get(id=1)

tasks = Task.objects.filter(assigned_to=person, time_stamp__year=person.time_stamp.utcnow().year)

我所有的模型都有time_stamp,所以我使用person对象来获取当前年份