python教程从基础到精通,第9课—日期与时间
wptr33 2025-06-24 17:16 39 浏览
Hello,小伙伴们,祝大家五.一玩得快乐!
刚学习完了七大数据类型,今天咱们来学习日期与时间的表示方法。
Python标准库中提供了时间和日期的支持:
calendar:日历相关;
time、datetime:时间相关;
格式化当前时间:
time模块:time.strftime('%Y-%m-%d', time.localtime(time.time()))
datetime模块:datetime.datetime.now().strftime('%Y-%m-%d')
1、time模块
时间的主要三种表示方式:
1)时间戳:1970-1-1至今的秒数(float),time.time();
2)格式化时间字符串:如'2018-11- 07 20:23',time.strftime('%Y-%m-%d', struct_time);
3)结构化时间time.struct_time:包含年月日等的元组,time.localtime(tm);
1.1、时间格式化
其中,struct_time是一个9元组:
格式化输出见下表:
1.2、time模块的应用
可以获取当前时间的年月日时分秒,可以延时或计时,输出精确到毫秒(%f为微秒,去掉后三位则近似毫秒)。
光看函数很晦涩,所以咱们还是先来看一下这些函数的应用吧:
import time
#time,从 1970 年 1 月 1 日 00:00:00 到当前时间的秒数
a=time.time()
print(a)
#ctime,显示现在时间, Fri Apr 28 22:56:29 2023
print(time.ctime())
#sleep
# Start : Fri Apr 28 23:10:53 2023
# End : Fri Apr 28 23:10:53 2023
print("Start : %s" % time.ctime(a))
time.sleep(5) #浅睡眠5秒钟
print("End : %s" % time.ctime(a))
#localtime,以年月日的形式显示现在时间
#time.struct_time(tm_year=2023, tm_mon=4, tm_mday=28,
#tm_hour=23, tm_min=10, tm_sec=53, tm_wday=4, tm_yday=118, tm_isdst=0)
b=time.localtime(a)
print(b)
print(time.strftime('%Y-%m-%d %H:%M:%S',b)) # 显示年-月-日-时-分-秒
print(time.strftime('%Y-%m-%d %H:%M',b)) # 显示年-月-日-时-分
print(time.strftime('%Y-%m-%d',b)) # 2023-04-28
#gmtime
#time.struct_time(tm_year=2023, tm_mon=4, tm_mday=28, tm_hour=15,
#tm_min=10, tm_sec=53, tm_wday=4, tm_yday=118, tm_isdst=0)
print("Local time in UTC format :",time.gmtime(a))
#mktime
b=(2019,8,6,10,40,34,1,218,0)
print("Current Time in seconds :",time.mktime(b))
#asctime,Tue Aug 6 10:40:34 2019
print("Current Time in local format :",time.asctime(b))
#strftime
c = time.localtime() # get struct_time
d = time.strftime("%m/%d/%Y, %H:%M:%S", c)
print("String representing date and time:",d) #04/28/2023, 23:10:58
#strptime
e = "06 AUGUST, 2019"
f = time.strptime(e, "%d %B, %Y")
print(f)
#time.struct_time(tm_year=2019, tm_mon=8, tm_mday=6, tm_hour=0,
#tm_min=0, tm_sec=0, tm_wday=1, tm_yday=218, tm_isdst=-1)
1.3、time模块中主要函数
1.4、休眠及运行时间
2、datetime模块
datetime模块定义了下面这几个类:
2.1、date类
date类定义了一些常用的类方法与类属性:
示例代码:
from datetime import date
import time
print('最大日期:', date.max) #最大日期: 9999-12-31
print('最小日期:', date.min) #最小日期: 0001-01-01
print('最小日期单位:', date.resolution) #最小日期单位: 1 day, 0:00:00
print('今天日期:', date.today()) #今天日期: 2023-04-29
print('根据时间戮,返回一个date对象:', date.fromtimestamp(time.time()))
#根据时间戮,返回一个date对象: 2023-04-29
2.2、date提供的实例方法和属性
还可以作日期的加减,示例代码:
from datetime import datetime, date, timedelta
today = date.today()
print(today) #2023-04-29
print(today.year) #2023
print(today.month) #4
print(today.replace(year=2017)) #2017-04-29,今年换成2017
print(today.weekday()) #5,星期五
print(today.isoweekday()) #6,从周天开始算起第几天
print(today.isocalendar()) #datetime.IsoCalendarDate(year=2023, week=17, weekday=6)
print(today.isoformat()) # 2023-04-29,返回格式如’YYYY-MM-DD’的字符串
print(today.strftime('%Y-%m-%d')) # 2023-04-29,按"年-月-日"格式输出日期
print(today.toordinal()) # 738639,格里历的今天
import datetime
day1 = datetime.date(2020,9,1)
day2 = datetime.date(2021,9,1)
day3 = day1 + timedelta(6)
day4 = day2 - timedelta(6)
print(day2 - day1) #365 days, 0:00:00
print(day2 > day1) #True
print(day3) #2021-09-07
print(day4) #2021-08-26
2.3、time类
time类的构造函数如下:(其中参数tzinfo,它表示时区信息。)
class datetime.time(hour[, minute[, second[, microsecond[, tzinfo]]]])
time类定义的类属性:
time类提供的实例方法和属性:
像date一样,也可以对两个time对象进行比较,或者相减返回一个时间间隔对象。这里就不提供例子了。
2.4、datetime类
datetime是date与time的结合体,包括date与time的所有信息。它的构造函数如下:datetime.datetime(year, month, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]),各参数的含义与date、time的构造函数中的一样,要注意参数值的范围。
datetime类定义的类属性与方法:
示例代码:
from datetime import datetime
import time
print('最大日期:', datetime.max)
print('最小日期:', datetime.min)
print('最小日期单位:', datetime.resolution)
print('today():', datetime.today())
print('now():', datetime.now())
print('utc样式的时间:', datetime.utcnow())
print('将本地时间作为输入:', datetime.fromtimestamp(time.time()))
print('将UTC时间作为输入:', datetime.utcfromtimestamp(time.time()))
date_str = "2022-01-01 12:00:00"
date_obj = datetime.strptime(date_str, '%Y-%m-%d %H:%M:%S') #成了日期变量
print(date_obj) #2022-01-01 12:00:00
输出结果
像date一样,也有同样的方法和属性,也可以对两个datetime对象进行比较,或者相减返回一个时间间隔对象,或者日期时间加上一个间隔返回一个新的日期时间对象。
2.5、timedelta类、tzinfo类
(1)timedelta类
通过timedelta函数返回一个timedelta对象,也就是一个表示时间间隔的对象。函数参数情况如下所示:
class datetime.timedelta([days[, seconds[, microseconds[, milliseconds[, minutes[, hours[, weeks]]]]]]])
其没有必填参数,简单控制的话第一个整数就是多少天的间隔的意思:
datetime.timedelta(10)
两个时间间隔对象可以彼此之间相加或相减,返回的仍是一个时间间隔对象。而更方便的是一个datetime对象如果减去一个时间间隔对象,那么返回的对应减去之后的datetime对象,然后两个datetime对象如果相减返回的是一个时间间隔对象。这很是方便。
(2)tzinfo类
tzinfo是一个抽象类,不能被直接实例化。需要派生子类,提供相应的标准方法。datetime模块并不提供tzinfo的任何子类。最简单的方式是使用pytz模块。
3、Calendar模块
此模块的函数都是日历相关的,星期一是默认的每周第一天,星期天是默认的最后一天。更改设置需调用calendar.setfirstweekday()函数。
示例代码如下 :
import calendar
c0 = calendar.firstweekday() # 输出:0
calendar.setfirstweekday(1) # 设置周一为1
c1 = calendar.firstweekday() # 输出:1
print(calendar.isleap(2022)) # False
print(calendar.leapdays(2000,2022)) # 6
print(calendar.month(2022, 9, w=2, l=1)) #后面两项可省
# September 2022
# Tu We Th Fr Sa Su Mo
# 1 2 3 4 5
# 6 7 8 9 10 11 12
# 13 14 15 16 17 18 19
# 20 21 22 23 24 25 26
# 27 28 29 30
print(calendar.monthcalendar(2022,9))
# [[0, 0, 1, 2, 3, 4, 5], [6, 7, 8, 9, 10, 11, 12], [13, 14, 15, 16, 17, 18, 19],
# [20, 21, 22, 23, 24, 25, 26], [27, 28, 29, 30, 0, 0, 0]]
print(calendar.monthrange(2022, 9)) # (3, 30)
print(calendar._monthlen(2022, 9)) # 30
print(calendar.weekday(2022,9,30)) # 4
print(calendar._prevmonth(2022, 1)) # (2021, 12)
print(calendar._prevmonth(2022, 4)) # (2022, 3)
print(calendar._nextmonth(2022, 12)) # (2023, 1)
print(calendar._nextmonth(2022, 9)) # (2022, 10)
愉快学习的时光总是过得很快,一不小心又到结尾啦。
先来给自己一个奖励,双手举起,yeah!
有什么问题可以关注我/私信我/加好友,让我们一起成长吧。
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 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+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
redission YYDS spring boot redission 使用
-
SparkSQL——DataFrame的创建与使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)