繁体   English   中英

如何使用 model 对象作为 django-filter MultipleChoiceFilter 的选择

[英]How to use model objects as choices for django-filter MultipleChoiceFilter

我正在使用 Django 过滤器,我希望其中一个字段( supervisor )成为ChoiceFilter ,其中选择是来自 model 的对象。 最有效的方法是什么? 我尝试关注这篇文章,但无论我进行什么更改,都会出现错误(当前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 model 中添加为主管的所有人员。

我不是 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()]

在您提到的链接中,我相信DatedResource.objects.all().values_list('date', flat=True).distinct())返回一个字符串数组

在您的代码people.objects.all().values_list('supervisor', flat=True).distinct()将返回一个 int 字符串 - 记录的 ID,因为它是外键

Ananya 的回答帮助我正确了解了该语句返回的内容,但在考虑了错误以及通常如何构建选择列表之后,我意识到我需要它来返回一个元组(而不仅仅是一个值)。 这是最终工作的相关代码:

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM