Django - 将查询集添加到FilterSet上的字段时出现问题

问题描述 投票:0回答:1

我有一些过滤器工作正常,但现在我尝试将一个查询集添加到FilterSet上的字段,并在加载页面时失败。

我正在使用Django 2.1.1与Python 3.6和Django-filter 2.0.0。

view

def search_jobs(request):
    job_list = Job.objects.filter(project__status="P", is_deleted="False")
    job_filter = JobsListFilter(request.GET, queryset=job_list)
    return render(request, 'webplatform/jobs_list_filter.html', {'filter': job_filter})

filter

class JobsListFilter(django_filters.FilterSet):

    # LINE ADDED - the following line is the added queryset 
    projects = Project.objects.filter(status="P", is_deleted="False") 

    skills = WorkerSkills.objects.filter(
        id__in=Job.objects.values_list('required_skills__id', flat=True).distinct())

    worker_job = django_filters.CharFilter(method='my_filter')
    required_skills = django_filters.ModelMultipleChoiceFilter(queryset=skills, widget=forms.SelectMultiple)

    # LINE ADDED - The following line is the one that adds the queryset inside the field I want to filter.
    project = django_filters.ChoiceFilter(queryset=projects)

    compensation_type = django_filters.ChoiceFilter(choices=Job.COMPENSATION_TYPE, widget=forms.RadioSelect)

    class Meta:
        model = Job
        fields = ['worker_job', 'required_skills', 'project', 'compensation_type']

    def my_filter(self, queryset, worker_job, value):
        return queryset.filter(
            worker_job__icontains=value
        ) | queryset.filter(
            work_description__icontains=value
        )

代码工作时没有在FilterSet上添加行LINE ADDED。但问题是,在project这个领域,它只是让我在创建的所有项目之间进行选择,我想只有那些真正需要的项目(在代码上应用queriset)。

但是在代码中添加这些行,当我使用调试模式时,我可以看到在字段project上应用的查询集给出了预期的结果。但是,在视图的return上抛出以下错误。

TypeError at /platform/search/jobs/ __init__() got an unexpected keyword argument 'queryset'

所以我不知道我做错了什么,因为我使用的是在required_skills字段上使用的相同结构,只添加了一个只包含我想要的对象的查询集,它应该可以工作。

python django django-filter
1个回答
0
投票

正如@MoisésHiraldo在评论中所说,问题是我不得不在django_filters.ModelChoiceFilter面前使用django_filters.ChoiceFilter

© www.soinside.com 2019 - 2024. All rights reserved.