如何在Django admin中过滤filter_horizo​​ntal?

时间:2014-04-09 16:31:09

标签: python django django-admin

我正在寻找一种在过滤后的查询集的基础上使用filter_horizo​​ntal的方法。

我尝试将它与自定义管理器一起使用:

在models.py中:

class AvailEquipManager(models.Manager):
    def get_query_set(self):
        return super(AvailEquipManager, self).get_query_set().filter(id=3)

class Equipment(models.Model):
    description = models.CharField(max_length=50)
    manufacturer = models.ForeignKey(Manufacturer)
    [...]
    objects = models.Manager()
    avail = AvailEquipManager()

    def __unicode__(self):
        return u"%s" % (self.description)

在admin.py中:

class SystemAdmin(admin.ModelAdmin):
    filter_horizontal = ('equipment',) # this works but obviously shows all entries
    #filter_horizontal = ('avail',)     # this does not work

所以问题是,我如何减少filter_horizo​​ntal的左侧只显示特定的项目?

2 个答案:

答案 0 :(得分:18)

我找到了一个解决方案,通过调整我在Google Groups

中找到的另一个问题的答案

它适用于自定义ModelForm,如下所示:

创建一个新的forms.py:

from django import forms
from models import Equipment

class EquipmentModelForm(forms.ModelForm):
    class Meta:
        model = Equipment

    def __init__(self, *args, **kwargs):
        forms.ModelForm.__init__(self, *args, **kwargs)
        self.fields['equipment'].queryset = Equipment.avail.all()

然后在admin.py中:

class SystemAdmin(admin.ModelAdmin):
    form = EquipmentModelForm
    filter_horizontal = ('equipment',) 

希望这可以帮助其他人。

答案 1 :(得分:1)

老问题,但无论如何:

根据您的特定要求,可能更容易在limit_choices_to关系字段上设置equipment属性。这适用于ForeignKey字段以及ManyToManyField上。

根据Django docs,此属性

设置此字段在此字段的可用选项的限制 使用ModelForm或管理员...

一个最小的示例,假设您有一个System多对多字段的equipment模型:

class Equipment(models.Model):
    available = models.BooleanField(default=True)


class System(models.Model):
    equipment = models.ManyToManyField(to=Equipment,
                                       limit_choices_to={'available': True})


class SystemAdmin(admin.ModelAdmin):
    filter_horizontal = ['equipment']

这使用available标志,但是也可以使用更复杂的查询。