如何解决如何编写一个根据当前日期设置默认页面的分页器?
我有大量按日期排序的课程列表。我想包含分页器,以便它始终在当前日期设置默认页面(如果存在此类课程,如果不是最近的课程)。甚至可以这样做吗?
from django.contrib.auth.models import Lesson
from django.core.paginator import Paginator
lesson_list = Lesson.objects.all().order_by('datetime')
paginator = Paginator(user_list,10)
解决方法
您可以根据 Lesson
是否为今天使用 conditional expression 注释您的 QuerySet,然后使用该注释对您的 QuerySet 进行排序。
from datetime import date # for typing
from django.db.models import BooleanField,Case,Value,When
from django.utils import timezone
current_date: date = timezone.now().date()
lesson_list = Lesson.objects.annotate(
lesson_today=Case(
When(datetime__date=current_date,then=Value(True)),default=Value(False),output_field=BooleanField()
)
).order_by('-lesson_today','-datetime')
- 使用 Django 的 built-in timezone utility 获取当前日期时间。使用
.date()
从日期时间对象中获取日期对象。 -
annotate()
带有名为lesson_today
的字段的 QuerySet。 -
lesson_today
的值是一个布尔值Case()
,其中Lesson.datetime
具有与当前日期匹配的年、月和日。使用__date
下标确保我们不会尝试匹配DateTimeField
的小时、分钟和秒组件。 - 先按
-lesson_today
排序意味着先对lesson_today=True
的对象进行排序。然后将剩余的对象按时间倒序排序(例如未来的课程)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。