欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django filter動態(tài)過濾與排序?qū)崿F(xiàn)過程解析

 更新時間:2020年11月26日 15:11:39   作者:-零  
這篇文章主要介紹了Django filter動態(tài)過濾與排序?qū)崿F(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

前期準(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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python兩個list[]相加的實現(xiàn)方法

    python兩個list[]相加的實現(xiàn)方法

    這篇文章主要介紹了python兩個list[]相加的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 解析Python中的變量、引用、拷貝和作用域的問題

    解析Python中的變量、引用、拷貝和作用域的問題

    這篇文章主要介紹了Python中的變量、引用、拷貝和作用域的相關(guān)問題,是Python學(xué)習(xí)過程當(dāng)中必會的基礎(chǔ)知識,需要的朋友可以參考下
    2015-04-04
  • Python數(shù)學(xué)建模學(xué)習(xí)模擬退火算法約束條件處理示例解析

    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ù)處理詳解

    這篇文章主要介紹了基于Python的身份證驗證識別和數(shù)據(jù)處理,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • python簡單實現(xiàn)操作Mysql數(shù)據(jù)庫

    python簡單實現(xiàn)操作Mysql數(shù)據(jù)庫

    本文給大家分享的是在python中使用webpy實現(xiàn)簡單的數(shù)據(jù)庫增刪改查操作的方法,非常的簡單,有需要的小伙伴可以參考下
    2018-01-01
  • python flask中動態(tài)URL規(guī)則詳解

    python 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ū)別說明

    這篇文章主要介紹了聊聊python在linux下與windows下導(dǎo)入模塊的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • Python字典dict常用方法函數(shù)實例

    Python字典dict常用方法函數(shù)實例

    這篇文章主要介紹了Python字典dict常用方法函數(shù)實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • python 實現(xiàn)判斷ip連通性的方法總結(jié)

    python 實現(xiàn)判斷ip連通性的方法總結(jié)

    下面小編就為大家分享一篇python 實現(xiàn)判斷ip連通性的方法總結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • pyside+pyqt實現(xiàn)鼠標(biāo)右鍵菜單功能

    pyside+pyqt實現(xiàn)鼠標(biāo)右鍵菜單功能

    這篇文章主要為大家詳細(xì)介紹了pyside+pyqt實現(xiàn)鼠標(biāo)右鍵菜單功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02

最新評論