如何使用模型对象作为 django-filter MultipleChoiceFilter 的选择
How to use model objects as choices for django-filter MultipleChoiceFilter
我正在使用 Django-filter,我希望其中一个字段 (supervisor
) 是一个 ChoiceFilter
,其中选项是模型中的对象。最有效的方法是什么?我尝试关注 ,但无论我更改什么(当前 cannot unpack non-iterable int object
),总是出现错误。
# models.py
class people(models.Model):
namelast = models.CharField(max_length=100, verbose_name='Last Name')
namefirst = models.CharField(max_length=100, verbose_name='First Name')
supervisor = models.ForeignKey('self', blank=True, null=True, on_delete=models.SET_NULL, verbose_name='Supervisor')
def __str__(self):
return "%s %s" % (self.namefirst, self.namelast)
# filters.py
class office_filter(django_filters.FilterSet):
supervisor = django_filters.ChoiceFilter(choices=[], lookup_expr='icontains', label='Supervisor')
# other fields
class Meta:
model = people
fields = ['namelast', 'namefirst', 'supervisor']
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
try:
self.filters['supervisor'].extra['choices'] = [x for x in
people.objects.all().values_list('supervisor', flat=True).distinct()]
except (KeyError, AttributeError):
pass
目标是让 supervisor
字段成为在 people
模型中分配为主管的所有人员的漂亮菜单。
我不是 100% 确定,但你能试试吗?
[people.objects.get(pk=x[0]) for x in people.objects.all().values_list('supervisor', flat=True).distinct()]
或
[people.objects.get(id=x[0]) for x in people.objects.all().values_list('supervisor', flat=True).distinct()]
你提到的 link 我相信
DatedResource.objects.all().values_list('date', flat=True).distinct())
returns 一个字符串数组
在你的代码中
people.objects.all().values_list('supervisor', flat=True).distinct()
return 一个 int 字符串 - 记录的 ID,因为它是一个外键
帮助我正确理解了那个陈述 return,但在思考错误以及选择列表通常是如何构建之后,我意识到我需要它来 return 一个元组(不仅仅是一个值)。这是最终起作用的相关代码:
class office_filter(django_filters.FilterSet):
supervisor = django_filters.ChoiceFilter(choices=[], label='Supervisor')
#...
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
try:
self.filters['supervisor'].extra['choices'] = [(people.objects.get(pk=x).id, people.objects.get(pk=x)) for x in people.objects.all().values_list('supervisor', flat=True).distinct() if x is not None]
except (KeyError, AttributeError):
pass
重要的部分是:(people.objects.get(pk=x).id, people.objects.get(pk=x))
而不仅仅是 people.objects.get(pk=x)
。
还必须删除过滤器字段中的 lookup_expr
。
我正在使用 Django-filter,我希望其中一个字段 (supervisor
) 是一个 ChoiceFilter
,其中选项是模型中的对象。最有效的方法是什么?我尝试关注 cannot unpack non-iterable int object
),总是出现错误。
# models.py
class people(models.Model):
namelast = models.CharField(max_length=100, verbose_name='Last Name')
namefirst = models.CharField(max_length=100, verbose_name='First Name')
supervisor = models.ForeignKey('self', blank=True, null=True, on_delete=models.SET_NULL, verbose_name='Supervisor')
def __str__(self):
return "%s %s" % (self.namefirst, self.namelast)
# filters.py
class office_filter(django_filters.FilterSet):
supervisor = django_filters.ChoiceFilter(choices=[], lookup_expr='icontains', label='Supervisor')
# other fields
class Meta:
model = people
fields = ['namelast', 'namefirst', 'supervisor']
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
try:
self.filters['supervisor'].extra['choices'] = [x for x in
people.objects.all().values_list('supervisor', flat=True).distinct()]
except (KeyError, AttributeError):
pass
目标是让 supervisor
字段成为在 people
模型中分配为主管的所有人员的漂亮菜单。
我不是 100% 确定,但你能试试吗?
[people.objects.get(pk=x[0]) for x in people.objects.all().values_list('supervisor', flat=True).distinct()]
或
[people.objects.get(id=x[0]) for x in people.objects.all().values_list('supervisor', flat=True).distinct()]
你提到的 link 我相信
DatedResource.objects.all().values_list('date', flat=True).distinct())
returns 一个字符串数组
在你的代码中
people.objects.all().values_list('supervisor', flat=True).distinct()
return 一个 int 字符串 - 记录的 ID,因为它是一个外键
class office_filter(django_filters.FilterSet):
supervisor = django_filters.ChoiceFilter(choices=[], label='Supervisor')
#...
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
try:
self.filters['supervisor'].extra['choices'] = [(people.objects.get(pk=x).id, people.objects.get(pk=x)) for x in people.objects.all().values_list('supervisor', flat=True).distinct() if x is not None]
except (KeyError, AttributeError):
pass
重要的部分是:(people.objects.get(pk=x).id, people.objects.get(pk=x))
而不仅仅是 people.objects.get(pk=x)
。
还必须删除过滤器字段中的 lookup_expr
。