Django笔记之数据库函数之日期函数
日期函数主要介绍两个大类,Extract() 和 Trunc()
Extract() 函数作用是提取日期,比如我们可以提取一个日期字段的年份,月份,日等数据
Trunc() 的作用则是截取,比如 2022-06-18 12:12:12,我们可以根据需求获取到日期 2020-06-18,或者更细粒度到时分秒
这次我们用到下面这个 model:
class Experiment(models.Model):start_datetime = models.DateTimeField()start_date = models.DateField(null=True, blank=True)start_time = models.TimeField(null=True, blank=True)end_datetime = models.DateTimeField(null=True, blank=True)end_date = models.DateField(null=True, blank=True)end_time = models.TimeField(null=True, blank=True)
我们还是将其放到 blog/models.py 下,相关的 migration 操作这里不多做介绍
- Extract()
- Trunc()
1、Extract()
这个函数接受日期时间字段名称,和查询的年、月、日、时、分、秒等作为参数,提取出相应的值以整数类型返回
日期类型字段包括:DateTimeField,DateField,TimeField
提取的类型列举如下:
- year——年份
- quarter——季度
- month——月份
- day——某日
- week——周数,一年的第几周
- weekday——周几,周日的值是1,周一是2,一直到周六是7
- hour——小时
- minute——分钟
- second——秒数
首先创建测试用的数据:
from datetime import datetime
start = datetime(2015, 6, 15, 12, 30, 56)
end = datetime(2015, 7, 2, 17, 21, 43)from blog.models import Experiment
Experiment.objects.create(start_datetime=start, start_date=start.date(),end_datetime=end, end_date=end.date())
新增字段获取开始时间的年份,周数,周几以及该天的小时数
from blog.models import Experiment
from django.db.models.functions import Extractexperiment = Experiment.objects.annotate(start_year=Extract('start_datetime', 'year'),start_week=Extract('start_datetime', 'week'),start_week_day=Extract('start_datetime', 'week_day'),start_hour=Extract('start_datetime', 'hour')
).get(id=1)print(experiment.start_year)
print(experiment.start_week)
print(experiment.start_week_day)
print(exprtiment.start_hour)
搜索特定年份数据
Extract() 函数的用法也可以用于搜索特定的日期的某一项,比如某年,某月等
Experiment.objects.filter(start_datetime__year=Extract('end_datetime', 'year'))
具体到日期某一项的用法
前面介绍了 Extract() 函数的用法是,接收字段名和日期项,Django 同时提供了另一种简便的、比Extract()函数更具体的用法。
比如我们需要需要搜索年,可以直接使用函数为 ExtractYear()
搜索月,使用函数 ExtractMonth()等等。
每一种在我们上面可接收的参数都有其对应的函数,传参为需要处理的字段,以下是使用示例:
from blog.models import Experiment
from django.db.models.functions import ExtractYear, ExtractWeek
expriment = Experiment.objects.annotate(start_year=ExtractYear('start_datetime'),start_week=ExtractWeek('start_datetime')
).get(id=1)print(expriment.start_year)
print(expriment.start_week)
如果是周数、时、分、秒的操作,函数名将上面的年月日的英文替换即可
2、Trunc()
这是一个对日期和时间截取的函数,我们可以将时间精确到 年、季度、月、日、时、分、秒
接受三个参数:
- expression: 字段,可以是 DateField, DateTimeField, TimeField 等
- kind: 精确到的程度,可以是 year,day,quarter等
- output_field: 输出格式,可以根据 kind 的值设置到最小值,如果不传这个参数,则默认是expression 的值
假设一个日期时间为 2022–05-16 12:34:56
我们可以挨个处理一下:
# 创建数据
from datetime import datetime
start_datetime = datetime(year=2022, month=5, day=16, hour=12, minute=34, second=56)Experiment.objects.create(start_datetime=start_datetime)from django.db.models.functions import Trunc
from django.db import modelsexperiment = Experiment.objects.annotate(start_year=Trunc('start_datetime', 'year', output_field=models.DateField()),start_quarter=Trunc('start_datetime', 'quarter', output_field=models.DateField()),start_month=Trunc('start_datetime', 'month', output_field=models.DateField()),start_day=Trunc('start_datetime', 'day', output_field=models.DateField()),start_hour=Trunc('start_datetime', 'hour', output_field=models.DateTimeField()),start_minute=Trunc('start_datetime', 'minute', output_field=models.DateTimeField()),start_second=Trunc('start_datetime', 'second', output_field=models.DateTimeField()),
).get(id=2)
然后挨个 print() 他们的结果如下:
>>> print(experiment.start_year)
2022-01-01
>>> print(experiment.start_quarter)
2022-04-01
>>> print(experiment.start_month)
2022-05-01
>>> print(experiment.start_day)
2022-05-16
>>> print(experiment.start_hour)
2022-05-16 12:00:00+00:00
>>> print(experiment.start_minute)
2022-05-16 12:34:00+00:00
>>> print(experiment.start_second)
2022-05-16 12:34:56+00:00
需要注意的是,截取到年、月、季度的数据,因为不关心当前时间刻度之下的数据,所以日期的日,都会被置为1,时间都会是0
从输出的结果看,日期时间都精确到了我们设置的细度,那么我们就可以利用这个来进行年度、月度、季度、以及日度等一些数据的统计
接下来以日度数据为例,我们做一下统计,统计每一天的数据的数量:
from django.db.models import Count
Experiment.objects.annotate(start_day=Trunc("start_datetime", "day", output_field=models.DateField())).values("start_day").annotate(count_day=Count("id"))
与 Extract() 函数类似,Trunc() 函数也有一些可以直接操作到时间的函数,比如 TruncYear(), TruncMonth() 这种,这里就不展开介绍了。
以上就是本篇笔记全部内容,下一篇将介绍数据库函数里计算公式相关函数。
相关文章:
Django笔记之数据库函数之日期函数
日期函数主要介绍两个大类,Extract() 和 Trunc() Extract() 函数作用是提取日期,比如我们可以提取一个日期字段的年份,月份,日等数据 Trunc() 的作用则是截取,比如 2022-06-18 12:12:12,我们可以根据需求…...
系统架构师---开发方法---敏捷开发
目录 前言 极限编程 四大价值观 沟通 简单 反馈 勇气 尊重: 十二个最佳实践 计划游戏 小型发布 隐喻 简单设计 测试先行 重构 结对编程 集体代码所所有制 持续集成 每周工作40小时 现场客户 编码标准 前言 2001年2月,在美国的犹他州…...
数据中心液冷技术:规模扩张的新里程碑
数据中心液冷技术:规模扩张的新里程碑 数据中心的液冷技术正处在规模扩张的关键阶段。这篇文章将深入探讨液冷技术的发展历程,当前的应用状况,以及未来的发展趋势。 目录 液冷技术的发展历程液冷技术的当前应用状况液冷技术的优势与挑战数据…...
页面静态化(模板引擎Freemarker)
1、浏览器请求web服务器 2、服务器渲染页面,渲染的过程就是向jsp页面(模板)内填充数据(模型)。 3、服务器将渲染生成的页面返回给浏览器。 所以模板引擎就是:模板数据输出,Jsp页面就是模板,页面中嵌入的jsp标签就是数据&#x…...
详细记录Pycharm配置已安装好的Conda虚拟环境
当安装好conda环境之后,想要在Pycharm中使用,那么就要在Pycharm中导入,我这里使用的pycharm-professional-2023.2这个版本,下面是详细步骤: 1.打开File->Settings: 2.找到Project——>Python Inter…...
photoshop生成器引入到electron项目(electron与photoshop建立通信)
Photoshop引入了nodejs,在启动的时候,通过pipe调起nodejs运行时核心generator-builtin,通过KLVR机制与ps进行通信和交互,同时会加载用户编写的扩展。 这里记录一下引入时的踩坑过程 generator-core就是它的源码,elect…...
Stable Diffuion webui Mac版本安装过程
系统环境 操作系统:MacOS Ventura13.5 芯片:Apple M2 Max Python: 3.10 安装前置准备 git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git注意事项:修改源码内全部 git clone 链接,设置代理 https://ghpr…...
ARM64 指令用法学习整理
1. CBZ 当我们谈论ARM64指令集时,CBZ(Compare and Branch on Zero)是一种条件分支指令。它用于在寄存器上进行比较,并且如果该寄存器的值为零,则跳转到指定的标签或地址。 CBZ指令的基本语法如下: CBZ &…...
stable-diffusion 模型效果+prompt
摘自个人印象笔记,图不完整可查看原笔记:https://app.yinxiang.com/fx/55cda0c6-2af5-4d66-bd86-85da79c5574ePrompt运用规则及技巧 : 1. https://publicprompts.art/(最适用于OpenArt 线上模型 https://openart.ai/)…...
uniapp 小兔鲜儿 - 首页模块(1)
目录 自定义导航栏 静态结构 安全区域 通用轮播组件 静态结构 自动导入全局组件 全局组件类型声明 .d.ts文件 注册组件 vue/runtime-core 首页 – 轮播图指示点 首页 – 获取轮播图数据 首页 – 轮播图数据类型并渲染 首页 – 轮播图总结 首页分类 首页 – 前…...
selenium.webdriver Python爬虫教程
文章目录 selenium安装和使用 selenium安装和使用 pip install selenium 下载对应的浏览器驱动 实例化浏览器 from selenium import webdriverbrowser webdriver.Chrome()元素定位 控制浏览器...
USB-SC-09编程电缆驱动程序安装说明
USB-SC-09编程电缆驱动程序安装说明 概述 USB编程电缆是通过将电脑的USB口模拟成传统的串行口(通常为COM3),从而使编程软件SWOPC-FXGP/WIN和GPP通过USB-SC-09编程电缆与FX系列PLC进行通信。 功能 ● 支持的操作系统Windows XP/ Windows2000 …...
ONVIF对讲功能漫谈
ONVIF对讲功能漫谈 前言一、onvif对讲功能和onvif协议关系大吗?二、如何上报设备支持onvif对讲功能呢?三、onvif协议中哪个接口上报音频解码配置?四、献上抓包报文:前言 本篇文章尝试使用提问的方式来分享onvif对讲功能那点事。 一、onvif对讲功能和onvif协议关系大吗? on…...
计算文本相似度
目录 Python中的difflib模块模块用法报告涉及的符号实现文本对比普通文本对比文本对比生成HTML报告 余弦相似度sklearn安装使用sklearn的余弦相似度词袋模型 Jaccard相似度编辑距离(Levenshtein距离)TF-IDFWord2VecDoc2VecBERT结论 Python中的difflib模块…...
oracle 增加控制文件
oracle 增加控制文件 1、看control_file路径 SQL> show parameter controlNAME TYPE VALUE ------------------------------------ ----------- ------------------------------ control_file_record_keep_time integer …...
OpenFeign超时时间设置不生效问题排查
最近升级springboot 3,突然发现配置文件中的openFeign的超时时间设置不生效了 之前配置如下: feign: client: config: default: connectTimeout: 3000 readTimeout: 5000 查资料都是说ribbon或者hystrix的超时时间设置问…...
Go和Java实现原型模式
Go和Java实现原型模式 下面将通过一个克隆的示例来说明原型模式的使用。 1、原型模式 原型模式是用于创建重复的对象,同时又能保证性能。这种类型的设计模式属于创建型模式,它提供了一种创建对 象的最佳方式之一。 这种模式是实现了一个原型接口&am…...
linux I/O性能优化
Linux 文件系统 磁盘和文件系统的关系: 磁盘为系统提供了最基本的持久化存储。 文件系统则在磁盘的基础上,提供了一个用来管理文件的树状结构。 文件系统工作原理 索引节点和目录项 文件系统,本身是对存储设备上的文件,进行组织…...
PHP最简单自定义自己的框架model使用(七)
1、实现model使用效果 2、自动加载model,KJ.php //自动加载文件public static function _autoload($className){switch ($className){//自动model类case substr($className,-5)Model:$path MODEL./.$className..php;if(is_file($path)) include $path;break;//自动加载控制器…...
程序猿成长之路之密码学篇-分组密码加密模式及IV(偏移量)的详解
Cipher.getInstance("AES/ECB/PKCS5Padding"); Cipher cipher Cipher.getInstance("AES/CBC/PKCS5Padding"); 在进行加解密编程的时候应该有很多小伙伴接触过以上的语句,但是大伙儿在编码过程中是否了解过ECB/CBC的含义、区别以及PKCS5Padding…...
终极指南:如何利用awesome-wasm实现高效WebAssembly内存池与对象重用
终极指南:如何利用awesome-wasm实现高效WebAssembly内存池与对象重用 【免费下载链接】awesome-wasm 😎 Curated list of awesome things regarding the WebAssembly (wasm) ecosystem. 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-wasm …...
自动驾驶感知入门:如何用Python仿真FMCW毫米波雷达(测距、测速、测角完整流程)
自动驾驶感知实战:Python仿真FMCW毫米波雷达全流程解析 毫米波雷达正成为自动驾驶系统的核心传感器之一。想象一下,当你需要验证一个雷达算法却苦于没有价值数十万元的硬件设备时,代码仿真就成了最经济高效的解决方案。本文将带你用Python从零…...
日系润滑油巨头加速中国本土化布局 出光润滑油经销商大会释放三大信号
2026年4月23日,出光润滑油(中国)有限公司在古都西安召开全国经销商大会。这场以"同心固本 乘骥追光"为主题的年度盛会,不仅交出了2025年销售量同比增长30%的成绩单,更释放出日系润滑油品牌在中国市场战略转型…...
AI Agent Harness Engineering 多模态能力构建:文本、图像、语音的融合应用
AI Agent Harness Engineering 多模态能力构建:文本、图像、语音的融合应用 本文面向有一定AI Agent开发基础的工程师,从零到一讲解如何通过Harness架构标准化接入多模态能力,解决传统Agent模态碎片化、上下文割裂、扩展困难的核心痛点,最终实现可生产级别的多模态智能体。…...
VSCode + LaTeX Workshop:打造比 TexStudio 更顺手的 Linux 论文写作环境
VSCode LaTeX Workshop:打造比 TexStudio 更顺手的 Linux 论文写作环境 对于长期在Linux环境下撰写学术论文或技术报告的研究人员来说,编辑器的选择直接影响写作效率和体验。虽然TexStudio一直是LaTeX用户的首选,但VSCode配合LaTeX Workshop…...
Solid Edge 2023 新手上路:从软件下载到成功激活的保姆级图文指南(附资源与避坑要点)
1. 为什么选择Solid Edge 2023? 作为西门子旗下知名的三维CAD软件,Solid Edge 2023在工业设计领域一直保持着领先地位。我刚开始接触这款软件时,最直观的感受就是它的操作界面非常友好,即使是完全没有CAD基础的用户也能快速上手。…...
ConfettiSwiftUI快速入门:10分钟学会配置基础庆祝动画
ConfettiSwiftUI快速入门:10分钟学会配置基础庆祝动画 【免费下载链接】ConfettiSwiftUI SwiftUI Package for Configurable Confetti Animation 🎉 项目地址: https://gitcode.com/gh_mirrors/co/ConfettiSwiftUI ConfettiSwiftUI是一个功能强大…...
从‘装不上’到‘跑得飞起’:我的TensorFlow-GPU避坑实录与终极验证指南
从‘装不上’到‘跑得飞起’:我的TensorFlow-GPU避坑实录与终极验证指南 深夜两点,屏幕上第17次弹出"Could not load dynamic library cudart64_110.dll"的错误提示时,我意识到自己掉进了TensorFlow-GPU安装的"版本地狱"…...
nnUNetv2保姆级安装配置指南:从零搭建医学影像分割环境(含环境变量避坑)
nnUNetv2医学影像分割环境搭建全攻略:从零配置到实战避坑指南 医学影像分析领域的研究者常被环境配置的"暗坑"绊住脚步。作为当前最先进的自动医学图像分割框架,nnUNetv2的安装过程看似简单,实则隐藏着诸多环境变量、路径配置和依赖…...
怎样高效压缩视频图片:3步掌握CompressO跨平台压缩神器
怎样高效压缩视频图片:3步掌握CompressO跨平台压缩神器 【免费下载链接】compressO Convert any video/image into a tiny size. 100% free & open-source. Available for Mac, Windows & Linux. 项目地址: https://gitcode.com/gh_mirrors/co/compressO …...
