1

我正在使用DjangoandDRFDjangoFilterBackend过滤查询集结果。

如何将多个查询传递给同一个查询参数?

例如,如果我在 中设置了“id” filterset_fields=['id'],以启用按 ID 过滤用户。

要过滤 id 99,url看起来像这样:api/user/?id=99.

您将如何在一个请求中过滤多个 ID?甚至可能吗?

我希望能够做这样的事情: api/user/?id=99,133,234或者也许 api/user/?id=99&id=133&id=234.

这目前对我不起作用,它只返回最后一个参数。

谢谢!

4

2 回答 2

1

这并不明显,但有一种方法。您将需要使用filter_class = YourFilterSet而不是filterset_fields. 查询将是?id=99,133,234

from django_filters import BaseInFilter
from django_filters import NumberFilter

class NumberInFilter(BaseInFilter, NumberFilter):
    pass

class YourFilterSet(django_filters.FilterSet):
    id = NumberInFilter(field_name='id')
于 2021-06-16T17:51:38.443 回答
0

感谢@Alexandr Tatarinov!!

我可能会补充说 NumberInFilter 是一个虚构的名称,您可以随意称呼它。此外,为了获得相同的字符串功能,您只需创建另一个过滤器类并继承名为 CharFilter 的 Django-Filter,如下所示:

from django_filters import BaseInFilter, NumberFilter, CharFilter

class NumberInFilter(BaseInFilter, NumberFilter):    
    pass

class CountryInFilter(BaseInFilter, CharFilter):    
    pass

class YourFilterSet(django_filters.FilterSet):  
    id = NumberInFilter(field_name='id')  
    country = CountryInFilter(field_name='country')

现在你可以像这样调用 api 并且它可以工作了!
api/?id=12,33,543

api/?country=usa,panama,india

于 2021-06-20T14:35:14.987 回答