restful返回包含关键字的文章列表
目前有个需求,需要查询文章标题包含关键词的文章列表,实现方法如下三种:
- 通过重写GenericsAPIView或ViewSet里的get_queryset方法。
如:
class ContentGenericsView(generics.ListAPIView):
‘’’
通过重写get_querset来实现模糊查询搜索
‘’’
pagination_class = MyPageNations
permission_classes = (permissions.AllowAny,)
serializer_class = ContentSerializer
def get_queryset(self):
keyword = self.request.query_params.get('keyword')
if not keyword:
return Content.objects.all()
return Content.objects.filter(title__icontains=keyword)
- 使用django_filter过滤
from django_filters import rest_framework as filter
class ContentFilter(filter.FilterSet):
'''
自定义过滤器
__exact 精确等于 like 'aaa'
__iexact 精确等于 忽略大小写 ilike 'aaa'
__contains 包含 like '%aaa%'
__icontains 包含 忽略大小写 ilike '%aaa%',但是对于sqlite来说,contains的作用效果等同于icontains。
__gt 大于
__gte 大于等于
__lt 小于
__lte 小于等于
__in 存在于一个list范围内
__startswith 以...开头
__istartswith 以...开头 忽略大小写
__endswith 以...结尾
__iendswith 以...结尾,忽略大小写
__range 在...范围内
__year 日期字段的年份
__month 日期字段的月份
__day 日期字段的日
__isnull=True/False
'''
title_icontains= filter.CharFilter(field_name='title',lookup_expr='icontains')
class Meta:
model = Content
fields = ('title','author')
class ContentGenericsFilterView(generics.ListAPIView):
queryset = Content.objects.all().order_by('id')
pagination_class = MyPageNations
permission_classes = (permissions.AllowAny,)
serializer_class = ContentSerializer
filter_backends = (filter.DjangoFilterBackend,)
filter_class = ContentFilter
http://127.0.0.1:8000/contentlistfilter/?title_icontains=我