TimeField 不支持“之间”查找或不允许在该字段上进行连接

Nun*_*ang 3 django django-models django-orm

我有一个这样的模型:

class Article(models.Model):
    title = models.CharField(max_length=200)
    content = models.TextField()
    create_time = models.DateTimeField(auto_now_add=True,null=True)
Run Code Online (Sandbox Code Playgroud)

我在视图函数中编写了一条查询语句,如下所示:

from datetime import time
start_time = time(hour=17)
end_time = time(hour=18)
articles = Article.objects.filter(create_time__time__between=(start_time,end_time))
Run Code Online (Sandbox Code Playgroud)

但是Django引发异常django.core.exceptions.FieldError: Unsupported lookup 'between' for TimeField or join on the field not permitted.django文档说这是正确的。如果我想要过滤时间在17到18之间,我该怎么办?

Dan*_*man 5

不,BETWEEN 查找的 Django 语法是__range, 不是__between- 这似乎是__time文档中的一个错误。

articles = Article.objects.filter(create_time__time__range=(start_time,end_time))
Run Code Online (Sandbox Code Playgroud)

(我已经提交了 PR 来修复文档。)