Django實(shí)現(xiàn)drf搜索過濾和排序過濾
前言
當(dāng)我們需要對后臺的數(shù)據(jù)進(jìn)行過濾的時(shí)候,drf
有兩種,搜索過濾和排序過濾。
搜索過濾:比如我們想返回sex=1
的,那么我們就可以從所有數(shù)據(jù)中進(jìn)行篩選
排序過濾:比如我們想對價(jià)格進(jìn)行升序排列,就可以使用排序過濾
搜索過濾
在實(shí)際的使用過程中十分簡單,只需要在視圖類中配置一個(gè)全局變量filter_backends
,然后在search_fields
確定需要通過哪個(gè)字段進(jìn)行篩選
from rest_framework.filters import SearchFilter class CarView(ListAPIView): serializer_class = CarSerializer queryset = Car.objects.all() # 局部配置過濾類和排序類 filter_backends = [SearchFilter] # SearchFilter過濾類依賴的過濾條件 search_fields = ['name']
之后我們在訪問url
地址時(shí),就可以在url
后面添加?search="寶馬1系"
,那么我們就會過濾出name
="寶馬1系"的數(shù)據(jù)
排序過濾
跟搜索過濾一樣,只需要配置局部變量filter_backends
,然后配置ordering_fields
來確定通過哪個(gè)字段進(jìn)行排序
from rest_framework.filters import SearchFilter, OrderingFilter class CarView(ListAPIView): serializer_class = CarSerializer queryset = Car.objects.all() # 局部配置過濾類和排序類 filter_backends = [SearchFilter, OrderingFilter] # SearchFilter過濾類依賴的過濾條件 search_fields = ['name'] # 局部配置排序類 ordering_fields = ['price']
之后我們在訪問url
地址時(shí),就可以在url
后面添加?search="寶馬"&ordering="price"
,那么我們就會過濾出所有寶馬系列的車子,并且數(shù)據(jù)的排序按照車的價(jià)格從低到高排序
PS:過濾功能利用的是第三方包 django_filters,搜索和排序利用的是 Django DRF 提供的 filters
from rest_framework import filters # 搜索和排序功能 # 注意:這兩個(gè)是 DRF 提供的功能 from django_filters.rest_framework import DjangoFilterBackend # DjangoFilterBackend 是精確(查找)過濾,即 字段值必須要完全一樣才能匹配成功 import django_filters class GoodsFilter(django_filters.rest_framework.FilterSet): """商品的過濾類""" min_price = django_filters.NumberFilter(field_name="price", lookup_expr="gte") # field_name 表示要過濾字段;lookup_expr 表示 過濾時(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 表示 包含(忽略大小寫) class Meta: model = models.Goods # 關(guān)聯(lián)的表 fields = ["min_price","max_price","name"] # 過濾的字段 class GoodsPagination(PageNumberPagination): page_size = 10 page_size_query_param = "page_size" page_query_param = "p" max_page_size = 100 class GoodsListViewSet(mixins.ListModelMixin,GenericViewSet): """商品查看""" queryset = models.Goods.objects.all() # 沒 get_queryset() 這個(gè)過濾方法時(shí),需要寫上這一步的 queryset;有 get_queryset 方法時(shí),則不需要寫這一步,因?yàn)闀詣尤?get_queryset() 中找 queryset pagination_class = GoodsPagination # 方式三:自定義過濾功能(也包含搜索和排序功能) filter_backends = (DjangoFilterBackend,filters.SearchFilter,filters.OrderingFilter) # filters.SearchFilter 表示 搜索功能;filters.OrderingFilter 表示 排序功能 filterset_class = GoodsFilter # 把自定義的過濾類 GoodsFilter 賦值給 filterset_class search_fields = ('^name', 'goods_brief') # 搜索功能對應(yīng)的字段 # '^' Starts-with search;'=' Exact matches. ordering_fields = ("sold_num","add_time") # 排序功能對應(yīng)的字段 # 業(yè)務(wù)邏輯省略... """ # 過濾功能方式二 filter_backends = (DjangoFilterBackend,) # 過濾類型 filterset_fields = ("name","shop_price") # 過濾字段 # 這種的過濾只能滿足精確過濾 """ """ # 方式一:get_queryset()方法 def get_queryset(self): # 過濾方法; 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 """ """ 方式二:通過 django-filter # 1. pip install django-filter # 2. 把 "django-filters" 添加到 Django 的 INSTALLED_APPS 中 # 3. 在 filter_backends 中添加 DjangoFilterBackend,在 filterset_fields 中添加 過濾字段 這個(gè)方式的過濾是精確過濾,即 用戶傳過來的值必須和 對應(yīng)過濾字段的值完全一樣才能過濾出來; 如果想自定義過濾功能(例如想過濾出價(jià)格區(qū)間),可通過方式三 """ """ 方式三:通過 django-filter 自定義 過濾功能 1. 自定義一個(gè)過濾類 2. filter_backends = (DjangoFilterBackend,) 3. filterset_class = GoodsFilter # 把自定義的過濾類 GoodsFilter 賦值給 filterset_class """
到此這篇關(guān)于Django實(shí)現(xiàn)drf搜索過濾和排序過濾的文章就介紹到這了,更多相關(guān)drf搜索過濾和排序過濾內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python selenium抓取虎牙短視頻代碼實(shí)例
這篇文章主要介紹了Python selenium抓取虎牙短視頻代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03django API 中接口的互相調(diào)用實(shí)例
這篇文章主要介紹了django API 中接口的互相調(diào)用實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04Python免費(fèi)驗(yàn)證碼識別之ddddocr識別OCR自動庫實(shí)現(xiàn)
在Python爬蟲過程中,有些網(wǎng)站需要驗(yàn)證碼通過后方可進(jìn)入網(wǎng)頁,目的很簡單,就是區(qū)分是人閱讀訪問還是機(jī)器爬蟲,下面這篇文章主要給大家介紹了關(guān)于Python免費(fèi)驗(yàn)證碼識別之ddddocr識別OCR自動庫實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2022-02-02Python的內(nèi)建模塊itertools的使用解析
這篇文章主要介紹了Python的內(nèi)建模塊itertools的使用解析,itertools是python的迭代器模塊,itertools提供的工具相當(dāng)高效且節(jié)省內(nèi)存,Python的內(nèi)建模塊itertools提供了非常有用的用于操作迭代對象的函數(shù),需要的朋友可以參考下2023-09-09pytorch中retain_graph==True的作用說明
這篇文章主要介紹了pytorch中retain_graph==True的作用說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02ruff check文件目錄檢測--exclude參數(shù)設(shè)置路徑詳解
這篇文章主要為大家介紹了ruff check文件目錄檢測exclude參數(shù)如何設(shè)置多少路徑詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10Python實(shí)現(xiàn)語音識別和語音合成功能
聲音的本質(zhì)是震動,震動的本質(zhì)是位移關(guān)于時(shí)間的函數(shù),波形文件(.wav)中記錄了不同采樣時(shí)刻的位移。這篇文章主要介紹了Python實(shí)現(xiàn)語音識別和語音合成,需要的朋友可以參考下2019-09-09