百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

一文了解 Python 中的 datetime 的基本操作

wptr33 2024-12-06 20:05 31 浏览

Python 中有一个名为 DateTime 的内置模块,可以以多种方式处理日期和时间。在本文中,我们将介绍 Python 中的基本 DateTime 操作。

datetime.date()

使用 date() 生成日期对象,表示具有年、月和日的日期。

「语法格式:」

datetime.date( year, month, day)

strftime 方法以各种格式打印日、月和年。

from datetime import date
# 创建日期对象
current = date.today() 
# 输出当前年、月、日
print("当前日:", current.day)
print("当前月份:", current.month)
print("当前年份:", current.year)
# 以不同格式输出日期
format1 = current.strftime("%m/%d/%y")
print("格式1:", format1)  
format2 =  current.strftime("%b-%d-%Y")
print("格式2:", format2)
format3 = current.strftime("%d/%m/%Y")
print("格式3:", format3)     
format4 =  current.strftime("%B %d, %Y")
print("格式4:", format4)

输出:

当前日: 20
当前月份: 10
当前年份: 2023
格式1: 10/20/23
格式2: Oct-20-2023
格式3: 20/10/2023
格式4: October 20, 2023

「时间日期格式化符号:」

%y 两位数的年份表示(00-99)
%Y 四位数的年份表示(000-9999)
%m 月份(01-12)
%d 月内中的一天(0-31)
%H 24小时制小时数(0-23)
%I 12小时制小时数(01-12)
%M 分钟数(00=59)
%S 秒(00-59)
%j 年内的一天(001-366)
%p 本地A.M.或P.M.的等价符
%U 一年中的星期数(00-53)星期天为星期的开始
%w 星期(0-6),星期天为星期的开始
%W 一年中的星期数(00-53)星期一为星期的开始
%f 微秒,以6位数字表示(000001)
%x 本地相应的日期表示
%X 本地相应的时间表示
%Z 当前时区的名称
%z UTC 偏移量
%a 本地简化星期名称
%A 本地完整星期名称
%b 本地简化的月份名称
%B 本地完整的月份名称
%c 本地相应的日期表示和时间表示
%% %号本身

datetime.time()

使用 time() 生成的时间对象,表示本地时间。

「语法格式:」

datetime.time(hour, minute, second, microsecond)

from datetime import time
# 创建时间对象
defaultTime = time()
print("默认小时:", defaultTime.hour)
print("默认分钟:", defaultTime.minute)
print("默认秒:", defaultTime.second)
print("默认毫秒:", defaultTime.microsecond)
# 设置参数
time= time(hour=10, minute= 5, second=25, microsecond=55)
print("time:", time)

输出:

默认小时: 0
默认分钟: 0
默认秒: 0
默认毫秒: 0
time: 10:05:25.000055

datetime.datetime()

datetime.datetime() 显示日期和时间的组合。

from datetime import datetime
# 创建对象
current = datetime.now()
print(current)
print("日:", current.day)
print("月:", current.month)
print("年:", current.year)
print("时:", current.hour)
print("分:", current.minute)
print("秒:", current.second)
print("时间戳:", current.timestamp())
time = current.strftime("%H:%M:%S")
print("当前时间:", time)

输出:

2023-10-20 18:00:47.202527
日: 20
月: 10
年: 2023
时: 18
分: 0
秒: 47
时间戳: 1697796047.202527
当前时间: 18:00:47

datetime.timedelta()

datetime.timedelta() 返回一个时间,该时间表示两个日期、时间之间的差异。

from datetime import timedelta, datetime
date_time = datetime.now() 
print("当前日期时间:", date_time)
ten_days_after= date_time + timedelta(days = 10)
print('10天之后的日期时间:',ten_days_after)
ten_days_before= date_time - timedelta(days = 10)
print('10天之前的日期时间:',ten_days_before)
one_year_before_today= date_time + timedelta(days = 365)
print('一年后的日期时间:', one_year_before_today)
one_year_after_today= date_time - timedelta(days = 365)
print('一年前的日期时间:', one_year_after_today)
time_after_one_min = date_time + timedelta(seconds=10) * 6
print('一分钟之后的日期时间:', time_after_one_min)
# 正数时间差相当于timedelta(days=999999999, hours=23, minutes=59, seconds=59, microseconds=999999)
print("正数时间差 : ",timedelta.max)
# 负数时间差相当于timedelta(-999999999)
print("负数时间差:",timedelta.min)
# 两个时间的最小差值相当于timedelta(microseconds=1)。
print("最小差值:",timedelta.resolution)
print('一年的秒数:',timedelta(days = 365).total_seconds())

输出:

当前日期时间: 2023-10-20 18:42:04.593126
10天之后的日期时间: 2023-10-30 18:42:04.593126
10天之前的日期时间: 2023-10-10 18:42:04.593126
一年后的日期时间: 2024-10-19 18:42:04.593126
一年前的日期时间: 2022-10-20 18:42:04.593126
一分钟之后的日期时间: 2023-10-20 18:43:04.593126
正数时间差 :  999999999 days, 23:59:59.999999
负数时间差: -999999999 days, 0:00:00
最小差值: 0:00:00.000001
一年的秒数: 31536000.0

?

文章创作不易,如果您喜欢这篇文章,请关注、点赞并分享给朋友。如有意见和建议,请在评论中反馈!

?

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...