django rest framework 过滤时间操作
时间:2022-07-27
本文章向大家介绍django rest framework 过滤时间操作,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
通常我们会用到过滤两个时间段内的一些数据, 当我们用django rest framework的时候, 他可以根据字段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中时间区间过滤,排序
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 过滤时间操作就是小编分享给大家的全部内容了,希望能给大家一个参考。
- Django 1.10中文文档-第一个应用Part5-测试
- 设计模式(5)-己所不欲,施之于人(代理模式)
- Python标准库笔记(4) — collections模块
- 使用captcha模块生成图形验证码
- 设计模式(6)-装饰器(认识程序中的装饰器)
- Selenium Webdriver常用方法
- 设计模式(7)-模板(从事务处理应用的模板)
- Python NLP入门教程
- 设计模式(8)-状态模式(关注状态之间的变化)
- Python标准库笔记(6) — struct模块
- Golang中image/jpeg包和image/png包用法
- Python Webdriver 重新使用已经打开的浏览器实例
- Golang-实现图片缩放
- jbpm5.1介绍(2)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 从一次编译出发梳理概念: Jetty,Jersey,hk2,glassFish,Javax,Jakarta
- 《一起学sentinel》一、一起搭建sentinel服务
- InfluxDB和Grafana实现传感器数据的存储和可视化
- 样本相关性分析
- Android 序列化 Serializable与Parcelable
- 《一起学sentinel》二、初探sentinel的Slot
- Redis突然报错,今晚又不能回家了...
- 查询ElasticSearch:用SQL代替DSL
- Java开源框架中的设计模式以及应用场景
- 统一定制API返回格式,我只做了这几件事
- 《一起学sentinel》三、Slot的子类及实现之NodeSelectorSlot和ClusterBuilderSlot
- 《一起学sentinel》四、Slot的子类及实现之LogSlot和StatisticSlot
- 《一起学sentinel》五、Slot的子类及实现之AuthoritySlot和SystemSlot
- Python 之pyaudio使用随笔
- Determining 32 vs 64 bit in C++