使用对同一查询参数的多个查询使用“fieldset_filters”进行 DRF 过滤
DRF filtering with `fieldset_filters` using multiple queries for the same queryparam
我正在使用 Django
和 DRF
,以及 DjangoFilterBackend
来过滤查询集结果。
如何将多个查询传递给同一个查询参数?
例如,如果我在 filterset_fields=['id']
中设置了 'id',以启用按 ID 过滤用户。
要过滤 id 99,url
将如下所示:api/user/?id=99
.
如何在一个请求中过滤多个 ID?有可能吗?
我希望能够做这样的事情:api/user/?id=99,133,234
或者 api/user/?id=99&id=133&id=234
。
这目前对我不起作用,它只是 returns 最后一个参数。
谢谢!
这不是显而易见的,但有办法。您将需要使用 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')
我可能要补充一点,NumberInFilter 是一个虚构的名称,您可以随意命名。
同样为了获得相同的字符串功能,您只需创建另一个过滤器 class 并继承名为 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=美国、巴拿马、印度
我正在使用 Django
和 DRF
,以及 DjangoFilterBackend
来过滤查询集结果。
如何将多个查询传递给同一个查询参数?
例如,如果我在 filterset_fields=['id']
中设置了 'id',以启用按 ID 过滤用户。
要过滤 id 99,url
将如下所示:api/user/?id=99
.
如何在一个请求中过滤多个 ID?有可能吗?
我希望能够做这样的事情:api/user/?id=99,133,234
或者 api/user/?id=99&id=133&id=234
。
这目前对我不起作用,它只是 returns 最后一个参数。
谢谢!
这不是显而易见的,但有办法。您将需要使用 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')
我可能要补充一点,NumberInFilter 是一个虚构的名称,您可以随意命名。 同样为了获得相同的字符串功能,您只需创建另一个过滤器 class 并继承名为 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=美国、巴拿马、印度