我有一个带有DateTimeField字段的Django模型为“created_at”,现在我想在Django admin中为该字段添加一个过滤器,但我只需要年份字段而不是默认字段(今天,过去7天,本月) ,今年)。
这是我的模特:
在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 :(得分:2)
答案 1 :(得分:1)
您可以将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
它还提供了按月更好地过滤的能力,而不是自己实施。