av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

python - Django內使用filter過濾時間,只認年份不認月份是怎么回事?

瀏覽:108日期:2022-07-30 18:02:00

問題描述

想用Django開發一個個人博客,參考了網上的一些文章和Django文檔,目前做到日期歸檔這個功能,以下是有問題的View

class ArchiveView(ListView): template_name = 'blog.html' context_object_name = 'articles' def get_queryset(self): # 接收從url傳遞的year和month參數,轉為int類型 year = int(self.kwargs[’year’]) month = int(self.kwargs[’month’]) # 按照year和month過濾文章 article_list = ArticleModel.manager.filter(status=’p’, add_time__year=year, add_time__month=month).order_by(’-add_time’)for article in article_list: pdb.set_trace() article.content= markdown2.markdown(article.content, extras=[’fenced-code-blocks’], ) return article_list def get_context_data(self, **kwargs): return super(ArchiveView, self).get_context_data(**kwargs)

用pdb試了很久,最后發現問題出在這一句:

article_list = ArticleModel.manager.filter(status=’p’, add_time__year=year, add_time__month=month).order_by(’-add_time’)

其中add_time__month=month無法過濾到正確月份,導致結果的QuerySet為空;pdb調試上面這個View中的month變量和article.add_time.month又確實是一樣的,理論上應該可以得到我想要的文章。注:status=’p’和add_time__year=year都可以成功地找到符合條件的文章;也試過用Q,結果是一樣的。不知道問題描述清楚了沒有= =|||,我現在也沒有頭緒,如果大家也不知道,那么從經驗上來說,這個問題應該怎么去找解決辦法……

這是我的ArticleModels,還附帶了自定義的Manager,不知道會不會是因為這個影響到的。

class ArticleAchiveManage(models.Manager): def archive(self):date_list = ArticleModel.manager.dates(’add_time’, ’month’, order=’DESC’)# 獲取到降序排列的精確到月份且已去重的文章發表時間列表# 并把列表轉為一個字典,字典的鍵為年份,值為該年份下對應的月份列表date_dict = defaultdict(list)for d in date_list: date_dict[d.year].append(d.month)# 模板不支持defaultdict,因此我們把它轉換成一個二級列表,由于字典轉換后無序,因此重新降序排序return sorted(date_dict.items(), reverse=True)class ArticleModel(models.Model): STATUS_CHOICES = ( (’d’, ’草稿’), (’p’, ’已發布’)) category = models.ForeignKey(’CategoryModel’, verbose_name=’分類’, null=True) status = models.CharField(’文章狀態’, default=’d’, max_length=1, choices=STATUS_CHOICES) manager = ArticleAchiveManage() title = models.CharField(max_length=32, verbose_name=u’標題’) abstract = models.TextField(max_length=144, verbose_name=’摘要’, default=’’) content = models.TextField(verbose_name=u’內容’) add_time = models.DateTimeField(verbose_name=u’發表時間’, auto_now_add=True) last_modified_time = models.DateTimeField(’修改時間’, auto_now=True) read_times = models.PositiveIntegerField(verbose_name=u’閱讀次數’, default=0) bravo_times = models.PositiveIntegerField(verbose_name=u’點贊’, default=0) class Meta:verbose_name = ’文章’verbose_name_plural = verbose_name def __str__(self):return self.title

問題解答

回答1:

# 可以使用如下方式進行篩選,篩選的值格式和你DB中的格式對應,比如是2017/04/12還是2017-04-12article_list = ArticleModel.objects.filter(status=’p’, add_time__startswith=’2017-04-12’).order_by(’-add_time’)#如果只想根據年月來篩選就是article_list = ArticleModel.objects.filter(status=’p’, add_time__startswith=’2017-04’).order_by(’-add_time’)

標簽: Python 編程
主站蜘蛛池模板: 久久www免费人成看片高清 | 国产成人一区二区三区久久久 | 老司机精品福利视频 | 在线观看视频中文字幕 | 欧美亚洲高清 | 欧美精品乱码久久久久久按摩 | av中文字幕网 | 亚洲精品一区中文字幕乱码 | 国产露脸国语对白在线 | 成人在线免费观看视频 | 自拍视频国产 | www日韩欧美 | 久久久久综合 | 91亚洲国产成人久久精品网站 | 亚洲国产成人精品女人久久久 | 日韩精品一区二区三区视频播放 | 久久天天躁狠狠躁夜夜躁2014 | 日本一区二区三区在线观看 | 国产成人免费网站 | 欧美性视频在线播放 | 91视频国产一区 | 日韩精品区 | 一区二区三区免费在线观看 | 中文字幕精品一区二区三区精品 | 国产高清视频在线观看播放 | 久久成人人人人精品欧 | 亚洲 日本 欧美 中文幕 | 免费在线视频一区二区 | 免费看黄色视屏 | 亚洲综合无码一区二区 | 日本一区高清 | 婷婷色婷婷 | 正在播放国产精品 | 欧美精品一区在线 | 99久久久久久久久 | 91九色在线观看 | 老司机狠狠爱 | 一区二区视频在线 | 欧美视频三区 | 欧美一级黄色片免费观看 | 精品久久久久久久久久久 |