我正在寻找一种在过滤后的查询集的基础上使用filter_horizontal的方法。
我尝试将它与自定义管理器一起使用:
在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_horizontal的左侧只显示特定的项目?
答案 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
标志,但是也可以使用更复杂的查询。