rest_framework--过滤器filters--搜索

rest_framework–过滤器filters–搜索

  • view

    from rest_framework.pagination import PageNumberPagination
    from rest_framework import mixins
    from rest_framework import viewsets
    from rest_framework import filters
    
    
    from .models import Goods
    from .serializers import GoodsSerializer
    
    
    class GoodsPagination(PageNumberPagination):
        page_size = 10
        page_size_query_param = "page_size"
        page_query_param = "p"
        max_page_size = 100
    
    
    class GoodsListViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
        # 指定queryset
        queryset = Goods.objects.all()
    
        # 指定序列化类
        serializer_class = GoodsSerializer
    
        # 指定分页类
        pagination_class = GoodsPagination
    
        # 添加过滤器 这里可以吧django-filter过滤器添加进来 和 rest_framework的filters添加进来一起用, 也可以单个用, 看你的需求
        filter_backends = [filters.SearchFilter]
    
        # 指定搜索的字段
        search_fields = ['name', 'goods_brief', "goods_desc"]
    
  • settings

    INSTALLED_APPS = [
        'rest_framework',
    ]
    
  • url

    from django.conf.urls import url, include
    
    from rest_framework.routers import DefaultRouter
    
    from goods.views import GoodsListViewSet
    # 生成一个注册器实例对象
    router = DefaultRouter()
    # 将需要自动生成url的接口注册
    # 配置goods的url
    router.register(r'goods', GoodsListViewSet, base_name="goods-list")
    
    urlpatterns = [
        # 自动生成url
        url(r"^", include(router.urls)),
    ]
    
    
  • 效果图
    在这里插入图片描述

  • 官方说明

    SearchFilter

    SearchFilter级支持简单单的查询参数基于搜索和基于该admin界面的搜索功能

    在使用时,可浏览的API将包含一个SearchFilter控件:

    [外链图片转存失败(img-7SEWIfWN-1568464204672)(https://www.django-rest-framework.org/img/search-filter.png)]

    所述SearchFilter如果视图有一类将只应用于search_fields属性集。该search_fields属性应该是模型上文本类型字段的名称列表,例如CharFieldTextField

    from rest_framework import filters
    
    class UserListView(generics.ListAPIView):
        queryset = User.objects.all()
        serializer_class = UserSerializer
        filter_backends = [filters.SearchFilter]
        search_fields = ['username', 'email']
    

    这将允许客户端通过查询来过滤列表中的项目,例如:

    http://example.com/api/users?search=russell
    

    您还可以使用查找API双下划线表示法对ForeignKey或ManyToManyField执行相关查找:

    search_fields = ['username', 'email', 'profile__profession']
    

    默认情况下,搜索将使用不区分大小写的部分匹配。搜索参数可以包含多个搜索项,其应该是空格和/或逗号分隔。如果使用多个搜索项,则仅当所有提供的项匹配时,才会在列表中返回对象。

    搜索行为可以通过在其中添加各种字符来限制search_fields

    • '^'开始 - 搜索。
    • '='完全匹配。
    • '@'全文搜索。(目前只支持Django的MySQL后端。)
    • '$'正则表达式搜索。

    例如:

    search_fields = ['=username', '=email']
    

    默认情况下,搜索参数已命名'search',但可以使用该SEARCH_PARAM设置覆盖此参数。

    要根据请求内容动态更改搜索字段,可以对该子类进行子类化SearchFilter并覆盖该get_search_fields()函数。例如,以下子类仅搜索title查询参数title_only是否在请求中:

    from rest_framework import filters
    
    class CustomSearchFilter(filters.SearchFilter):
        def get_search_fields(self, view, request):
            if request.query_params.get('title_only'):
                return ['title']
            return super(CustomSearchFilter, self).get_search_fields(view, request)
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Django Rest Framework (DRF)支持模糊过滤(Fuzzy filtering)功能,可以帮助你在API中进行更精细的数据筛选。 要启用模糊过滤功能,你需要定义一个过滤器类,并在视图中使用它。以下是一个简单的例子: ```python from rest_framework import filters class MyFilter(filters.SearchFilter): search_param = 'q' # 定义模糊匹配的字段 search_fields = ['name', 'description'] class MyView(APIView): filter_backends = [MyFilter] def get(self, request): queryset = MyModel.objects.all() queryset = self.filter_queryset(queryset) serializer = MySerializer(queryset, many=True) return Response(serializer.data) ``` 在上面的例子中,我们定义了一个名为`MyFilter`的过滤器类,它继承自DRF自带的`SearchFilter`类。我们定义了一个`search_fields`属性,指定了要模糊匹配的字段。我们还定义了一个`search_param`属性,指定了要传递给API的查询参数的名称(默认为`search`)。 在视图中,我们将`MyFilter`添加到`filter_backends`列表中。然后我们通过调用`self.filter_queryset(queryset)`方法来过滤查询集(在`get`方法中)。 现在,我们可以在API中使用`q`参数进行模糊匹配。例如,我们可以通过以下方式获取所有`MyModel`对象中名称或描述中包含“django”的对象: ``` GET /myview/?q=django ``` DRF还支持其他类型的过滤器,例如`DjangoFilterBackend`和`OrderingFilter`等。你可以在DRF文档中了解更多信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

只因为你温柔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值