2017-10-12 38 views
1

我有一个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) 

但事实并非如此工作。 我该如何做到这一点? 请帮帮我! 在此先感谢!

回答

0

您可以将date_hierarchy = 'created_at'添加到您的管理员类。

class TaggedArticle(admin.ModelAdmin): 
    date_hierarchy = 'created_at' 
    fields = ['category_fit', 'article', 'link', 'relevant_feedback', 'category', 'user', 'email', 'created_at'] 
    list_display = ['article_id', 'link', 'user', 'created_at'] 
    list_filter = ['user', 'email'] 
    model = Tagged 

它还提供了按月,以更好的方式过滤比自己实现它的能力。

+0

Hi @Cai!它不起作用,仍然显示所有过滤选项,我只需要显示年份,它应该显示所有标签文章已经创建的所有年份。 –

+0

您可以从list_filter中移除created_at,过滤器将显示在所有列的顶部。 – Cai

+0

它还显示几个月,我怎样才能显示只有几年? –

相关问题