django rest framework 过滤时间操作
通常我们会用到过滤两个时间段内的一些数据,当我们用djangorestframework的时候,他可以根据字段filter_fields进行过滤,但是对于日期来说并不起作用,这个时候就需要我们设置重写queryset方法进行捕捉了
重写get_queryset()
defget_queryset(self): start=self.request.query_params.get('fault_start_time',None) stop=self.request.query_params.get('fault_end_time',None) ifstartandstop: returnmodels.ServerFaultRecord.objects.filter(fault_start_time__gte=start).filter(fault_end_time__lte=stop) returnmodels.ServerFaultRecord.objects.all()
补充知识:django中时间区间过滤,排序
1.过滤下载
pipinstalldjango-filter
2.下载后注册
INSTALLED_APPS=['django_filters',]
3.导入rest_framework
fromdjango_filtersimportrest_framework classDoctorsFilter(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.在类中的使用
fromdjango_filters.rest_frameworkimportDjangoFilterBackend fromrest_framework.viewsetsimportModelViewSet classDoctorsViewSet(ModelViewSet): filter_backends=[DjangoFilterBackend] #过滤其他的字段 filter_fields=('id','patient','doc_type',)#指向要过滤的类 filter_class=DoctorsFilter
2.排序
#1.导入OrderingFilter fromrest_framework.filtersimportOrderingFilter #2.在类中的使用 classCarsModelViewSet(ModelViewSet): queryset=models的类 serializer_class=序列化组件 filter_backends=[OrderingFilter] #/api/cars/?ordering=-id倒序#/api/cars/?ordering=id正序 ordering_fields=('id',)
以上这篇djangorestframework过滤时间操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。