我有一个Django模型,DateTimeField字段为“created_at”,现在我想在Django admin中为该字段添加一个过滤器,但我只需要年份字段而不是默认字段(今天,过去7天,本月,今年)。在Django中添加按年份过滤器admin
这里是我的模型:
在models.py
class TaggedArticle(models.Model):
user = models.ForeignKey(User, related_name='tagging')
email = models.EmailField(max_length=255)
category_fit = models.CharField(choices=choices, max_length=255)
article = models.ForeignKey(Article, related_name='articles')
link = models.URLField(max_length=255,)
relevant_feedback = models.TextField(blank=True)
category = models.CharField(max_length=255,)
created_at = models.DateTimeField(default=timezone.now, editable=False)
我试图覆盖admin.py为created_at领域:
class TaggedArticle(admin.ModelAdmin):
fields = ['category_fit', 'article', 'link', 'relevant_feedback', 'category', 'user', 'email', 'created_at']
list_display = ['article_id', 'link', 'user', 'created_at']
list_filter = ['user', 'email', 'created_at']
model = Tagged
def created_at(self, obj):
return self.Tagged.created_at.year
admin.site.register(Tagged, TaggedArticle)
但事实并非如此工作。 我该如何做到这一点? 请帮帮我! 在此先感谢!
Hi @Cai!它不起作用,仍然显示所有过滤选项,我只需要显示年份,它应该显示所有标签文章已经创建的所有年份。 –
您可以从list_filter中移除created_at,过滤器将显示在所有列的顶部。 – Cai
它还显示几个月,我怎样才能显示只有几年? –