Django filter動態(tài)過濾與排序?qū)崿F(xiàn)過程解析
前期準(zhǔn)備
在虛擬開發(fā)環(huán)境中安裝:
pip install django-filter
在Django的項目配置文件中安裝并配置django_filters應(yīng)用:
INSTALLED_APPS = [ ... 'django_filters', ] REST_FRAMEWORK = { # 過濾器默認(rèn)后端 'DEFAULT_FILTER_BACKENDS': ( 'django_filters.rest_framework.DjangoFilterBackend',), }
快速使用
model.py
class User(models.Model): # 模型字段 name = models.CharField(max_length=10, verbose_name="姓名") sex = models.BooleanField(default=1, verbose_name="性別") age = models.IntegerField(verbose_name="年齡") phone = models.CharField(max_length=20, null=True, verbose_name="電話") addr = models.CharField(max_length=100,null=True,verbose_name="地址") class Meta: db_table = "tb_user" verbose_name = "用戶" verbose_name_plural = verbose_name
新建filter.py:過濾器類
import django_filters from .models import User class UserFilter(django_filters.FilterSet): class Meta: model = User fields = ["name", "age"] #指定動態(tài)過濾的字段,默認(rèn)精準(zhǔn)匹配
注意:
Meta字段說明
model: 引用的模型,不是字符串
fields:指明過濾字段,可以是列表,列表中字典可以過濾,默認(rèn)是判等;也可以字典,字典可以自定義操作
exclude = ['password'] 排除字段,不允許使用列表中字典進行過濾
view.py
from django_filters.rest_framework import DjangoFilterBackend from rest_framework.generics import ListAPIView from rest_framework import filters class UserViewSet(ListAPIView): queryset = User.objects.all() #獲取數(shù)據(jù) serializer_class = UserModelSerializer #指定序列化類 filter_class = UserFilter # 指定過濾器類
serializers.py
from rest_framework import serializers from .models import User class UserModelSerializer(serializers.ModelSerializer): class Meta: model = User fields = "__all__"
urls.py
path('user/',UserViewSet.as_view()),
首先理解上面是動態(tài)過濾,前端在請求頭如下傳遞參數(shù),傳遞參數(shù)的個數(shù)是不同的,而動態(tài)過濾只會過濾:有參數(shù),且參數(shù)有值的項。
http://ip:port/user/?name=查找內(nèi)容&age=查找內(nèi)容
http://ip:port/user/?name=&age=查找內(nèi)容
http://ip:port/user/?name=查找內(nèi)容&age=
http://ip:port/user/?name=&age=
http://ip:port/user/
精準(zhǔn)過濾、模糊過濾并存
class UserFilter(django_filters.FilterSet): class Meta: model = User # fields = ["name", "age"] fields = { "name": ['exact','icontains'], "age": ['exact'], }
exact:默認(rèn)過濾方式,精確過濾
icontains:模糊過濾
http://ip:port/user/?name=查找內(nèi)容&name_icontains=查找內(nèi)容&age=查找內(nèi)容
范圍過濾
class UserFilter(django_filters.FilterSet): class Meta: model = User # fields = ["name", "age"] fields = { "name": ['exact','icontains'], "age": ['exact','gte','lte'], }
對以上filter來說
name 精確查找
name__icontains 模糊查找
age 精準(zhǔn)查找
age__gte 大于等于
age__lte 小于等于
排序
class UserFilter(django_filters.FilterSet): #定義排序字段:依賴哪個字段排序 sort = django_filters.OrderingFilter(fields=('age',)) class Meta: model = User # fields = ["name", "age"] fields = { "name": ['exact','icontains'], "age": ['exact','gte','lte'], }
url示例
http://ip:port/user/?name=查找內(nèi)容&sort=age:表示升序
http://ip:port/user/?name=查找內(nèi)容&sort=-age:表示降序
補充知識
這部分可以參考:https://zhuanlan.zhihu.com/p/110060840
過濾器可以自定義字段,開始我們這樣定義過濾字段,以及每個字段是相等運算,模糊匹配,還是范圍查詢,但是這樣的寫法可能不太直觀。
fields = {
"name": ['exact','icontains'],
"age": ['exact','gte','lte'],
}
我們可以做如下類型改變
class BookFilter(filters.FilterSet): btitle = filters.CharFilter(field_name='title',lookup_expr='icontains') pub_year = filters.CharFilter(field_name='bpub_date',lookup_expr='year') pub_year__gt = filters.CharFilter(field_name='bpub_date',lookup_expr='year__gt') bread__gt = filters.NumberFilter(field_name='bread',lookup_expr="gt") bread__lt = filters.NumberFilter(field_name='bread',lookup_expr="lt") class Meta: model = Bookinfo fields = ['title','bread','bcomment']
http://127.0.0.1:8000/book/?title=&bread=&bcomment=&btitle=%E5%B0%84%E9%9B%95&pub_year=&pub_year__gt=&bread__gt=&bread__lt=
過濾器每個字段內(nèi)部配置:
field_name: 過濾字段名,為對應(yīng)模型中字段名
lookup_expr: 查詢時所要進行的操作,是等值,范圍、模糊匹配等
過濾器字段類型:
CharFilter 字符串類型
BooleanFilter 布爾類型
DateTimeFilter 日期時間類型
DateFilter 日期類型
DateRangeFilter 日期范圍
TimeFilter 時間類型
NumberFilter 數(shù)值類型,對應(yīng)模型中IntegerField, FloatField, DecimalField
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 在django中查詢獲取數(shù)據(jù),get, filter,all(),values()操作
- django filter過濾器實現(xiàn)顯示某個類型指定字段不同值方式
- Django:使用filter的pk進行多值查詢操作
- 解決導(dǎo)入django_filters不成功問題No module named ''django_filter''
- django model 條件過濾 queryset.filter(**condtions)用法詳解
- django admin管理工具自定義時間區(qū)間篩選器DateRangeFilter介紹
- Django models filter篩選條件詳解
- django 自定義過濾器(filter)處理較為復(fù)雜的變量方法
相關(guān)文章
Python數(shù)學(xué)建模學(xué)習(xí)模擬退火算法約束條件處理示例解析
線性規(guī)劃(Linear programming),是研究線性約束條件下線性目標(biāo)函數(shù)的極值問題的優(yōu)化方法,常用于解決利用現(xiàn)有的資源得到最優(yōu)決策的問題,本文使用懲罰函數(shù)法,分析模擬退火算法處理線性規(guī)劃問題,相關(guān)內(nèi)容也適用于非線性規(guī)劃問題2021-10-10基于Python的身份證驗證識別和數(shù)據(jù)處理詳解
這篇文章主要介紹了基于Python的身份證驗證識別和數(shù)據(jù)處理,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11python簡單實現(xiàn)操作Mysql數(shù)據(jù)庫
本文給大家分享的是在python中使用webpy實現(xiàn)簡單的數(shù)據(jù)庫增刪改查操作的方法,非常的簡單,有需要的小伙伴可以參考下2018-01-01python flask中動態(tài)URL規(guī)則詳解
今天小編就為大家分享一篇python flask中動態(tài)URL規(guī)則詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11聊聊python在linux下與windows下導(dǎo)入模塊的區(qū)別說明
這篇文章主要介紹了聊聊python在linux下與windows下導(dǎo)入模塊的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03python 實現(xiàn)判斷ip連通性的方法總結(jié)
下面小編就為大家分享一篇python 實現(xiàn)判斷ip連通性的方法總結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04pyside+pyqt實現(xiàn)鼠標(biāo)右鍵菜單功能
這篇文章主要為大家詳細(xì)介紹了pyside+pyqt實現(xiàn)鼠標(biāo)右鍵菜單功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-02-02