Django實(shí)現(xiàn)drf搜索過(guò)濾和排序過(guò)濾
當(dāng)我們需要對(duì)后臺(tái)的數(shù)據(jù)進(jìn)行過(guò)濾的時(shí)候,drf有兩種,搜索過(guò)濾和排序過(guò)濾。搜索過(guò)濾:比如我們想返回sex=1的,那么我們就可以從所有數(shù)據(jù)中進(jìn)行篩選排序過(guò)濾:比如我們想對(duì)價(jià)格進(jìn)行升序排列,就可以使用排序過(guò)濾
搜索過(guò)濾在實(shí)際的使用過(guò)程中十分簡(jiǎn)單,只需要在視圖類(lèi)中配置一個(gè)全局變量filter_backends,然后在search_fields確定需要通過(guò)哪個(gè)字段進(jìn)行篩選
from rest_framework.filters import SearchFilterclass CarView(ListAPIView): serializer_class = CarSerializer queryset = Car.objects.all() # 局部配置過(guò)濾類(lèi)和排序類(lèi) filter_backends = [SearchFilter] # SearchFilter過(guò)濾類(lèi)依賴(lài)的過(guò)濾條件 search_fields = [’name’]
之后我們?cè)谠L問(wèn)url地址時(shí),就可以在url后面添加?search='寶馬1系',那么我們就會(huì)過(guò)濾出name='寶馬1系'的數(shù)據(jù)
跟搜索過(guò)濾一樣,只需要配置局部變量filter_backends,然后配置ordering_fields來(lái)確定通過(guò)哪個(gè)字段進(jìn)行排序
from rest_framework.filters import SearchFilter, OrderingFilterclass CarView(ListAPIView): serializer_class = CarSerializer queryset = Car.objects.all() # 局部配置過(guò)濾類(lèi)和排序類(lèi) filter_backends = [SearchFilter, OrderingFilter] # SearchFilter過(guò)濾類(lèi)依賴(lài)的過(guò)濾條件 search_fields = [’name’] # 局部配置排序類(lèi) ordering_fields = [’price’]
之后我們?cè)谠L問(wèn)url地址時(shí),就可以在url后面添加?search='寶馬'&ordering='price',那么我們就會(huì)過(guò)濾出所有寶馬系列的車(chē)子,并且數(shù)據(jù)的排序按照車(chē)的價(jià)格從低到高排序
PS:過(guò)濾功能利用的是第三方包 django_filters,搜索和排序利用的是 Django DRF 提供的 filters
from rest_framework import filters # 搜索和排序功能 # 注意:這兩個(gè)是 DRF 提供的功能from django_filters.rest_framework import DjangoFilterBackend # DjangoFilterBackend 是精確(查找)過(guò)濾,即 字段值必須要完全一樣才能匹配成功import django_filtersclass GoodsFilter(django_filters.rest_framework.FilterSet): '''商品的過(guò)濾類(lèi)''' min_price = django_filters.NumberFilter(field_name='price', lookup_expr='gte') # field_name 表示要過(guò)濾字段;lookup_expr 表示 過(guò)濾時(shí)要進(jìn)行的操作,gte 表示 大于等于 max_price = django_filters.NumberFilter(field_name='price', lookup_expr='lte') # lte 小于等于 name = django_filters.CharFilter(field_name='name',lookup_expr='icontains') # icontains 表示 包含(忽略大小寫(xiě)) class Meta:model = models.Goods # 關(guān)聯(lián)的表fields = ['min_price','max_price','name'] # 過(guò)濾的字段class GoodsPagination(PageNumberPagination): page_size = 10 page_size_query_param = 'page_size' page_query_param = 'p' max_page_size = 100class GoodsListViewSet(mixins.ListModelMixin,GenericViewSet): '''商品查看''' queryset = models.Goods.objects.all() # 沒(méi) get_queryset() 這個(gè)過(guò)濾方法時(shí),需要寫(xiě)上這一步的 queryset;有 get_queryset 方法時(shí),則不需要寫(xiě)這一步,因?yàn)闀?huì)自動(dòng)去 get_queryset() 中找 queryset pagination_class = GoodsPagination# 方式三:自定義過(guò)濾功能(也包含搜索和排序功能) filter_backends = (DjangoFilterBackend,filters.SearchFilter,filters.OrderingFilter) # filters.SearchFilter 表示 搜索功能;filters.OrderingFilter 表示 排序功能 filterset_class = GoodsFilter # 把自定義的過(guò)濾類(lèi) GoodsFilter 賦值給 filterset_class search_fields = (’^name’, ’goods_brief’) # 搜索功能對(duì)應(yīng)的字段 # ’^’ Starts-with search;’=’ Exact matches. ordering_fields = ('sold_num','add_time') # 排序功能對(duì)應(yīng)的字段 # 業(yè)務(wù)邏輯省略...''' # 過(guò)濾功能方式二 filter_backends = (DjangoFilterBackend,) # 過(guò)濾類(lèi)型 filterset_fields = ('name','shop_price') # 過(guò)濾字段 # 這種的過(guò)濾只能滿(mǎn)足精確過(guò)濾 '''''' # 方式一:get_queryset()方法 def get_queryset(self): # 過(guò)濾方法; GenericAPIView 提供的方法queryset = models.Goods.objects.all()price_min = self.request.query_params.get('price_min',0)if price_min: queryset = queryset.filter(shop_price_gt=int(price_min))return queryset '''''' 方式二:通過(guò) django-filter # 1. pip install django-filter # 2. 把 'django-filters' 添加到 Django 的 INSTALLED_APPS 中 # 3. 在 filter_backends 中添加 DjangoFilterBackend,在 filterset_fields 中添加 過(guò)濾字段 這個(gè)方式的過(guò)濾是精確過(guò)濾,即 用戶(hù)傳過(guò)來(lái)的值必須和 對(duì)應(yīng)過(guò)濾字段的值完全一樣才能過(guò)濾出來(lái); 如果想自定義過(guò)濾功能(例如想過(guò)濾出價(jià)格區(qū)間),可通過(guò)方式三 '''''' 方式三:通過(guò) django-filter 自定義 過(guò)濾功能 1. 自定義一個(gè)過(guò)濾類(lèi) 2. filter_backends = (DjangoFilterBackend,) 3. filterset_class = GoodsFilter # 把自定義的過(guò)濾類(lèi) GoodsFilter 賦值給 filterset_class '''
到此這篇關(guān)于Django實(shí)現(xiàn)drf搜索過(guò)濾和排序過(guò)濾的文章就介紹到這了,更多相關(guān)drf搜索過(guò)濾和排序過(guò)濾內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. WML的簡(jiǎn)單例子及編輯、測(cè)試方法第1/2頁(yè)2. 前端html+css實(shí)現(xiàn)動(dòng)態(tài)生日快樂(lè)代碼3. XML基本概念XPath、XSLT與XQuery函數(shù)介紹4. el-input無(wú)法輸入的問(wèn)題和表單驗(yàn)證失敗問(wèn)題解決5. 關(guān)于html嵌入xml數(shù)據(jù)島如何穿過(guò)樹(shù)形結(jié)構(gòu)關(guān)系的問(wèn)題6. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)7. 不要在HTML中濫用div8. vue實(shí)現(xiàn)復(fù)制文字復(fù)制圖片實(shí)例詳解9. XML入門(mén)的常見(jiàn)問(wèn)題(三)10. XML入門(mén)的常見(jiàn)問(wèn)題(四)
