使用django开发博客过程记录5——日期归档和视图重写

本文介绍了如何使用Django的Mixin来实现博客文章的阅读次数计数功能,并提供了一种按日期范围筛选文章的方法。通过记录用户的最后访问时间来更新文章的阅读次数,同时给出了实现按特定年份和月份归档文章的具体代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

针对每条博客的观看次数我么是使用django的Mixin实现的:

    def get(self, request, *args, **kwargs):
        last_visit = request.session.get('last_visit')
        reset_last_visit_time = False

        if last_visit:
            last_visit_time = datetime.datetime.strptime(last_visit[:-7], "%Y-%m-%d %H:%M:%S")

            if (datetime.datetime.utcnow() - last_visit_time).seconds > 0:
                obj = super(ArticleDetailView, self).get_object()
                obj.views = obj.views + 1
                obj.save()
                reset_last_visit_time = True
        else:
            reset_last_visit_time = True

        if reset_last_visit_time:
            request.session['last_visit'] = str(datetime.datetime.utcnow())

        return super(ArticleDetailView, self).get(request, *args, **kwargs)

而根据日期归档则比较麻烦,借鉴了Mysql必知必会得到了思路代码如下:

class DateView(ListView):
    template_name = 'apps/full-width.html'
    context_object_name = 'article_list'
    paginate_by = 10

    def get_queryset(self):
        year = self.kwargs['year']
        month = self.kwargs['month']
        start_date = datetime.date(int(year), int(month), 1)
        end_date = datetime.date(int(year), int(month), 31)
        article_list = Article.objects.filter(create_time__range=(start_date, end_date))

        return article_list

 

转载于:https://www.cnblogs.com/selfimprovement/p/5982667.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值