django rest framework 過濾時間操作
通常我們會用到過濾兩個時間段內(nèi)的一些數(shù)據(jù), 當我們用django rest framework的時候, 他可以根據(jù)字段filter_fields進行過濾, 但是對于日期來說并不起作用, 這個時候就需要我們設置重寫queryset方法進行捕捉了
重寫get_queryset()
def get_queryset(self): start = self.request.query_params.get('fault_start_time', None) stop = self.request.query_params.get('fault_end_time', None) if start and stop: return models.ServerFaultRecord.objects.filter(fault_start_time__gte=start).filter(fault_end_time__lte=stop) return models.ServerFaultRecord.objects.all()
補充知識:django中時間區(qū)間過濾,排序
1.過濾下載
pip install django-filter
2.下載后注冊
INSTALLED_APPS=['django_filters',]
3.導入rest_framework
from django_filters import rest_framework class DoctorsFilter(rest_framework.FilterSet): authentication_classes = [TokenAuthentication] #開始時間 start_date = rest_framework.DateFilter(field_name='start_date', lookup_expr='gte') #結束時間 end_date = rest_framework.DateFilter(field_name='end_date', lookup_expr='lte')
4.在類中的使用
from django_filters.rest_framework import DjangoFilterBackend from rest_framework.viewsets import ModelViewSet class DoctorsViewSet(ModelViewSet): filter_backends = [DjangoFilterBackend] #過濾其他的字段 filter_fields = ('id', 'patient', 'doc_type',) #指向要過濾的類 filter_class = DoctorsFilter
2.排序
#1.導入OrderingFilter from rest_framework.filters import OrderingFilter #2.在類中的使用 class CarsModelViewSet(ModelViewSet): queryset =models的類 serializer_class=序列化組件 filter_backends = [OrderingFilter] #/api/cars/?ordering=-id 倒序 #/api/cars/?ordering=id 正序 ordering_fields = ('id', )
以上這篇django rest framework 過濾時間操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
python中getattr函數(shù)使用方法 getattr實現(xiàn)工廠模式
這篇文章主要介紹了python中getattr()這個函數(shù)的一些用法,大家參考使用吧2014-01-01使用wxpython實現(xiàn)的一個簡單圖片瀏覽器實例
這篇文章主要介紹了使用wxpython實現(xiàn)的一個簡單圖片瀏覽器實例,根據(jù)自己的特殊需求而寫,需要的朋友可以參考下2014-07-07python實現(xiàn)JAVA源代碼從ANSI到UTF-8的批量轉(zhuǎn)換方法
這篇文章主要介紹了python實現(xiàn)JAVA源代碼從ANSI到UTF-8的批量轉(zhuǎn)換方法,涉及Python針對文件操作與編碼轉(zhuǎn)換的相關技巧,需要的朋友可以參考下2015-08-08python實現(xiàn)m3u8格式轉(zhuǎn)換為mp4視頻格式
這篇文章主要為大家詳細介紹了python實現(xiàn)m3u8格式轉(zhuǎn)換為mp4視頻格式,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-02-02使用python創(chuàng)建Excel工作簿及工作表過程圖解
這篇文章主要介紹了使用python創(chuàng)建Excel工作簿及工作表,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-05-05