App下載

django filters實(shí)現(xiàn)數(shù)據(jù)過(guò)濾的示例代碼

幼稚園新童鞋 2021-08-20 10:08:46 瀏覽數(shù) (2818)
反饋

在Django中,實(shí)現(xiàn)數(shù)據(jù)過(guò)濾通常使用filters來(lái)進(jìn)行,那么怎么使用filters進(jìn)行文件過(guò)濾呢?來(lái)看看小編是怎么做的。

常用

當(dāng)前循環(huán). 作用
default 數(shù)據(jù)為空時(shí)設(shè)置默認(rèn)值
length 取變量長(zhǎng)度
filesizeformat 文件大小轉(zhuǎn)成可讀
slice 從指定位置到指定位切片
date datetime取到的時(shí)間,轉(zhuǎn)成指定格式
safe 防止XSS攻擊、加上safe才能傳標(biāo)簽
truncatechars 取摘顯示一段剩下的…

例子

{#格式   值|函數(shù)#}
{#    如果沒(méi)有值,那么使用默認(rèn)值#}
    <p>{{ bucunzai|default:'空的哦' }}</p>

{#    取出變量長(zhǎng)度#}
    <q>{{ name }}--{{ name|length }}</q>

{#      文件大小轉(zhuǎn)換成可讀型  kb 自動(dòng)轉(zhuǎn)成bm、g、tb#}
    <p>文件大小{{ file_size|filesizeformat }}</p>

{#    切片 從指定位置到指定位 ,例:第3位到-2位#}
    <p>切片:{{ slice_str|slice:'3:-2' }}</p>

{#    把datetime取到的時(shí)間,轉(zhuǎn)成指定格式#}
    <p>格式化:{{ now|date:'Y-m-d H:i:s' }}</p>

{#    如果后端內(nèi)容包含標(biāo)簽,那么加上safe 才能轉(zhuǎn)義(防止用戶直接加script標(biāo)簽作弊)防XSS攻擊#}
    <p>{{ h_html|safe }}</p>

{#    取摘要只顯示一段,指定取長(zhǎng)度后面...例:120個(gè)字符 #}
    <p>長(zhǎng)文本:{{ p_str|truncatechars:12 }}</p>

1、視圖

class UserView(ListAPIView):
    """用戶列表"""
    queryset = User.objects.all()
    serializer_class = UserSerializer
    filter_backends = (DjangoFilterBackend,)
    filter_class = UserMonthFilter  # 指定過(guò)濾類

2、過(guò)濾類

class RobotFilter(django_filters.FilterSet):
    # 使用過(guò)濾:URL?created_start_time=2020_01-20&created_end_time=2020_01-21
    robot_id = django_filters.CharFilter(field_name='id')
    machine_id = django_filters.CharFilter(field_name='machine_id')
    city = django_filters.CharFilter(field_name='city')
    # lookup_expr(可選)為判斷條件,field_name(必選)為模型類屬性,created_time查詢字符串
    created_time= django_filters.CharFilter(field_name='created_at', lookup_expr='startswith')
    created_start_time = django_filters.DateTimeFilter(field_name='created_at', lookup_expr='gt')
    created_end_time = django_filters.DateTimeFilter(field_name='created_at', lookup_expr='lt')
    problem_isnull = django_filters.BooleanFilter(field_name='problem', lookup_expr='isnull')
    name = django_filters.CharFilter(lookup_expr='iexact')  # iexact表示精確匹配, 并且忽略大小寫
    author = django_filters.CharFilter(lookup_expr='icontains') #icontains表示模糊查詢(包含),并且忽略大小寫
    price = django_filters.NumberFilter(look_expr='exact')  #exact表示精確匹配
    task_res_state = django_filters.CharFilter(method="get_task_res_state")
    
    def get_task_res_state(self, queryset, *arg):
        if str(arg[1]) == "0":  # arg[1]=('task_res_state', '0')
            task_res = (1, 2, 3)
        else:
            task_res = (0, 4, 5, 6)
        print(task_res)
        queryset = queryset.filter(task_res__in=task_res)
        return queryset
    class Meta:
        model = Robot
        fields = ['robot_id', 'machine_id', "city", "created_start_time", "created_end_time", 'created_time',
                  'firmware_version', 'state', "robot_type", "hardware_version", "exist_map", 'task_res_state']

到此這篇Django使用filters實(shí)現(xiàn)數(shù)據(jù)過(guò)濾的文章就就介紹到這了,更多django的相關(guān)學(xué)習(xí)內(nèi)容請(qǐng)搜索W3Cschool以前的文章或繼續(xù)瀏覽下面的相關(guān)文章。

0 人點(diǎn)贊