首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何使用模型对象作为django-filter MultipleChoiceFilter的选择

如何使用模型对象作为django-filter MultipleChoiceFilter的选择
EN

Stack Overflow用户
提问于 2020-07-03 01:51:46
回答 2查看 560关注 0票数 0

我正在使用Django-filter,我希望其中一个字段(supervisor)是一个ChoiceFilter,其中的选项是模型中的对象。最有效的方法是什么?我尝试遵循this post,但无论我做了什么更改(当前是cannot unpack non-iterable int object)都一直收到错误。

代码语言:javascript
代码运行次数:0
运行
复制
# 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模型中作为主管添加的所有人员。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-07-03 04:10:07

Ananya's answer帮助我正确地了解了语句返回的内容,但在考虑了错误和选择列表通常是如何构造的之后,我意识到我需要它来返回一个元组(而不仅仅是一个值)。以下是最终运行的相关代码:

代码语言:javascript
代码运行次数:0
运行
复制
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)

还必须删除filter字段中的lookup_expr

票数 1
EN

Stack Overflow用户

发布于 2020-07-03 02:24:50

我不是百分之百确定,但你能试一下吗?

代码语言:javascript
代码运行次数:0
运行
复制
[people.objects.get(pk=x[0]) for x in people.objects.all().values_list('supervisor', flat=True).distinct()]

代码语言:javascript
代码运行次数:0
运行
复制
[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的字符串-记录的it,因为它是一个外键

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62702314

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档