问题描述
我使用 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
。
这目前对我不起作用,它只返回最后一个参数。
谢谢!
解决方法
这个不明显,但是有办法。您将需要使用 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')
,
感谢@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=美国、巴拿马、印度