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

时间:2019-02-15 13:16:21

标签: python django django-filter

我有一些filterSets可以正常工作,但是现在我尝试将查询集添加到FilterSet上的字段,并且在加载页面时失败。

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

视图

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})

过滤器

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字段上,它只允许我在所有创建的项目之间进行选择,而我只希望包含真正需要的项目(将查询对象应用于代码)。

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

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

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

1 个答案:

答案 0 :(得分:0)

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