Django filter動(dòng)態(tài)過濾與排序?qū)崿F(xiàn)過程解析
前期準(zhǔn)備
在虛擬開發(fā)環(huán)境中安裝:
pip install django-filter
在Django的項(xiàng)目配置文件中安裝并配置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"] #指定動(dòng)態(tài)過濾的字段,默認(rèn)精準(zhǔn)匹配
注意:
Meta字段說明
model: 引用的模型,不是字符串
fields:指明過濾字段,可以是列表,列表中字典可以過濾,默認(rèn)是判等;也可以字典,字典可以自定義操作
exclude = ['password'] 排除字段,不允許使用列表中字典進(jìn)行過濾
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()),
首先理解上面是動(dòng)態(tài)過濾,前端在請(qǐng)求頭如下傳遞參數(shù),傳遞參數(shù)的個(gè)數(shù)是不同的,而動(dòng)態(tài)過濾只會(huì)過濾:有參數(shù),且參數(shù)有值的項(xiàng)。
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'],
}
對(duì)以上filter來說
name 精確查找
name__icontains 模糊查找
age 精準(zhǔn)查找
age__gte 大于等于
age__lte 小于等于
排序
class UserFilter(django_filters.FilterSet):
#定義排序字段:依賴哪個(gè)字段排序
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:表示降序
補(bǔ)充知識(shí)
這部分可以參考:https://zhuanlan.zhihu.com/p/110060840
過濾器可以自定義字段,開始我們這樣定義過濾字段,以及每個(gè)字段是相等運(yùn)算,模糊匹配,還是范圍查詢,但是這樣的寫法可能不太直觀。
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=
過濾器每個(gè)字段內(nèi)部配置:
field_name: 過濾字段名,為對(duì)應(yīng)模型中字段名
lookup_expr: 查詢時(shí)所要進(jìn)行的操作,是等值,范圍、模糊匹配等
過濾器字段類型:
CharFilter 字符串類型
BooleanFilter 布爾類型
DateTimeFilter 日期時(shí)間類型
DateFilter 日期類型
DateRangeFilter 日期范圍
TimeFilter 時(shí)間類型
NumberFilter 數(shù)值類型,對(duì)應(yīng)模型中IntegerField, FloatField, DecimalField
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 在django中查詢獲取數(shù)據(jù),get, filter,all(),values()操作
- django filter過濾器實(shí)現(xiàn)顯示某個(gè)類型指定字段不同值方式
- Django:使用filter的pk進(jìn)行多值查詢操作
- 解決導(dǎo)入django_filters不成功問題No module named ''django_filter''
- django model 條件過濾 queryset.filter(**condtions)用法詳解
- django admin管理工具自定義時(shí)間區(qū)間篩選器DateRangeFilter介紹
- Django models filter篩選條件詳解
- django 自定義過濾器(filter)處理較為復(fù)雜的變量方法
相關(guān)文章
python實(shí)現(xiàn)錄制全屏和選擇區(qū)域錄屏功能
這篇文章主要介紹了python實(shí)現(xiàn)錄制全屏和選擇區(qū)域錄屏功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
Python讀取含url圖片鏈接的txt文檔方法小結(jié)
這篇文章主要為大家詳細(xì)介紹了三種Python讀取含url圖片鏈接的txt文檔方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04
django項(xiàng)目登錄中使用圖片驗(yàn)證碼的實(shí)現(xiàn)方法
這篇文章主要介紹了django項(xiàng)目登錄中使用圖片驗(yàn)證碼的實(shí)現(xiàn)代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-08-08

