使用“fieldset_filters”对同一查询参数使用多个查询进行 DRF 过滤

问题描述

我使用 DjangoDRF,并使用 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=美国、巴拿马、印度

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...