Django笔记二十五之数据库函数之日期函数

yizhihongxing

本文首发于公众号:Hunter后端
原文链接: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 操作这里不多做介绍

  1. Extract()
  2. 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 Extract

experiment = 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 models

experiment = 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() 这种,这里就不展开介绍了。

以上就是本篇笔记全部内容,下一篇将介绍数据库函数里计算公式相关函数。

如果想获取更多后端相关文章,可扫码关注阅读:

image

原文链接:https://www.cnblogs.com/hunterxiong/p/17334992.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django笔记二十五之数据库函数之日期函数 - Python技术站

(0)
上一篇 2023年4月19日
下一篇 2023年4月19日

相关文章

  • Python二元算术运算常用方法解析

    下面是详细讲解“Python二元算术运算常用方法解析”的完整攻略。 1. 什么是二元算术运算? 二元算术运算是指对两个数运算的操作,包括加法、减法、乘法、除法等。 2. Python二元算术运算常用方法 2.1 加法运算 加法运算是指将两个数相加的操作,可以使用加号(+)进行运算。 下面是一个加法运算的示例: a = 5 b = 3 c = a + b pr…

    python 2023年5月14日
    00
  • python循环之彩色圆环实现示例

    下面是“Python循环之彩色圆环实现示例”的完整攻略。 Python循环之彩色圆环实现示例 1. 简介 在这个示例中,我们将用Python的turtle模块,使用循环语句实现彩色圆环的绘制。这个示例可以帮助我们熟悉Python中turtle模块的使用,以及掌握循环语句的使用方法,同时还可以让我们学习如何定义函数和使用列表等基础数据结构。 2. 前置知识 在…

    python 2023年5月13日
    00
  • 利用Python自动化操作AutoCAD的实现

    实现Python自动化操作AutoCAD的方案有多种,下面我将介绍其中一种比较常见的实现步骤: 1. 安装AutoCAD相关的Python库 目前较为流行的AutoCAD Python库有pyautocad和comtypes,我们这里以pyautocad的安装为例。 安装步骤: 安装pywin32 pyautocad包依赖于pywin32,需要先安装pywi…

    python 2023年5月19日
    00
  • Python机器学习入门(三)之Python数据准备

    Python机器学习入门(三)之Python数据准备主要讲解了如何对数据进行预处理和准备,以适应进行机器学习模型的训练。这里的数据准备主要包括数据清洗、特征工程和数据归一化等内容。 数据清洗 数据清洗是指对数据中的异常值、不一致值或缺失值等问题进行处理。下面是一些常见的数据清洗操作。 缺失值处理 缺失值是指数据中的一些属性没有取到值,这种情况在数据中很常见。…

    python 2023年6月3日
    00
  • Pandas的DataFrame如何做交集,并集,差集与对称差集

    Pandas是Python语言中用于数据分析和操作的常用库之一,而DataFrame是Pandas库中最重要的数据结构之一,它类似于Excel中的表格,可以方便地进行数据处理和运算。在DataFrame对象中,可以实现交集、并集、差集和对称差集的操作。 1. DataFrame的交集 利用Pandas的DataFrame对象的intersection()方法…

    python 2023年5月14日
    00
  • python代码有一行标黄问题的解决方案

    针对“python代码有一行标黄问题”的解决方案,我将按照以下步骤进行说明: 1. 问题描述 在编写Python代码时,如果出现了一行标黄,这通常意味着该行代码存在某种语法错误或问题,导致代码无法正常执行。此时我们需要针对该行代码进行调试和排查。 2. 解决方案 在解决该问题时,我们可以按照以下步骤进行: 步骤1:检查代码错误 首先,我们需要检查该行代码是否…

    python 2023年5月13日
    00
  • python保存数据到本地文件的方法

    下面是一个完整的 Python 保存数据到本地文件的方法攻略: 使用内置的open方法保存文本文件 Python内置的open()函数可以用来创建、编辑和读取文件。通过使用参数,您可以指定打开文件时使用的模式。以下是打开文件时可用的模式: “r” – 只读模式。默认模式。 “w” – 写模式。如果文件不存在,则会创建该文件。如果文件已存在,则会覆盖该文件。 …

    python 2023年6月3日
    00
  • Python代理IP爬虫的新手使用教程

    Python代理IP爬虫的新手使用教程 本攻略将介绍如何使用Python代理IP爬虫。我们将使用requests库发送HTTP请求,并使用代理IP来隐藏我们的真实IP地址。 安装requests库 在开始前,我们需要安装requests库。我们可以使用以下命令在命令行中安装requests库: pip install requests 发送HTTP请求 我们…

    python 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部