欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 锐评 > Django-filter

Django-filter

2024/11/30 8:38:32 来源:https://blog.csdn.net/zhiaidaidai/article/details/139637851  浏览:    关键词:Django-filter

准备工作

首先,确保你已经安装了django-filter包。如果没有,请使用以下命令安装:

pip install django-filter

然后,在你的settings.py文件中添加django_filters到INSTALLED_APPS列表中:

INSTALLED_APPS = [# ...'django_filters',
]

本机环境:

Django==3.2.15

django-filter==24.2

ps:安装的包是django-filter,但是在settings里面设置的却是django-filters。这也是蛮坑的一个点。

目的

一个TaskViewSet,带模型Task的,里面有两个自定义动作,一个是根据template_id过滤,一个是根据project_id过滤

filters.py:

那么我可以创建一个filters.py文件在应用目录中:

import django_filters
from .models import Taskclass TaskFilter(django_filters.FilterSet):class Meta:model = Taskfields = ['template_id', 'project_id']

注意如果过滤的字段本身就属于Task模型的字段,那么不用额外定义,如果过滤的条件字段不属于Task模型的字段,那么需要额外定义如下:
同时,如果想要定义精准过滤和模糊过滤,可以定义如下:

from django.db.models import Qfrom .models import BkHostclass BkHostFilter(django_filters.FilterSet):operator = django_filters.CharFilter(field_name='operator', method='filter_operator')class Meta:model = BkHostfields = {'host_id': ['exact'],'host_name': ['exact', 'icontains'],'host_innerip': ['exact', 'contains'],}def filter_operator(self, queryset, name, value):return queryset.filter(Q(operator__exact=value) | Q(operator__icontains=value))

其中icontains表示不区分大小写的模糊匹配。contains表示区分大小写的模糊匹配。

视图集

首先视图集本身要指定filter_class

class TaskViewSet(ModelViewSet):queryset = Task.objects.all()serializer_class = TaskSerializerlookup_field = "task_id"filter_class = TaskFilter

如果是自定义动作(即被@action装饰器修饰的)需要应用django-filter的话,需要在动作中再次手动指定

    @swagger_auto_schema(manual_parameters=[openapi.Parameter('template_id',openapi.IN_QUERY,type=openapi.TYPE_INTEGER,)])@action(detail=False, methods=["get"], url_path="list-by-template")def list_by_template(self, request):  # ……省略代码# 手动应用过滤器filterset = self.filter_class(request.GET, queryset=self.get_queryset())if not filterset.is_valid():return Response(filterset.errors, status=400)tasks = filterset.qs

如果是非自定义动作,可以直接如下使用:

tasks = self.filter_queryset(self.get_queryset())

路径匹配

注意django-filter会从路径参数中拿在filters.py中指定的字段。所以如上代码只接受路径:
http://{your-domain}:8000/tasks/list-by-template/?template_id=xxx

总结

如果是自定义动作,除非过滤条件比较复杂,不然不需要用django-filter,因为还要手动指定,比较复杂。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com