​一篇文章总结一下Python库中关于时间的常见操作

Karen110
• 阅读 971

前言

本次来总结一下关于Python时间的相关操作,有一个有趣的问题。

如果你的业务用不到时间相关的操作,你的业务基本上会一直用不到。

但是如果你的业务一旦用到了时间操作,你就会发现,淦,到处都是时间操作。。。

所以思来想去,还是总结一下吧,本次会采用类型注解方式。

time包

import time

时间戳

1970年1月1日00:00:00标准时区诞生到现在时间一共过了多少秒。

代码


timestamp = time.time()  # type:float
print(timestamp, type(timestamp))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

睡眠

有时候可能我们可能需要模仿一些IO请求,假装让程序休眠一下,所以需要用到timesleep函数。

代码


# 睡眠 1秒
time.sleep(1)

本地时区

本地时区需要用到timelocaltime方法。

代码


t = time.localtime()  # type:time.struct_time
print(t, type(t))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

localtime还能接收一个时间戳参数。

代码

# 将时间戳转换成 struct_time 对象
t = time.localtime(1606395685.1878598)  # type:time.struct_time
print(t, type(t))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

简单的时间格式

代码


t = time.ctime()  # type:str
print(t, type(t))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

虽然这个能把时间展示出来,但是这个格式实在是不是太好看。

同理,time.ctime()也是可以接收一个时间戳的。

代码


t = time.ctime(1606395685.1878598)  # type:str
print(t, type(t))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

时间格式化


日期格式 -> 字符串(strftime)

代码

t = time.localtime()  # type:time.struct_time
t_str = time.strftime("%Y-%m-%d", t)  # type:str
print(t_str, type(t_str))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

字符串日期 -> 日期(strptime)

代码

t_str = "2020-11-02"
t_time = time.strptime(t_str, "%Y-%m-%d")  # type:time.struct_time
print(t_time, type(t_time))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

格式化补充

主要有如下格式

格式 含义
%Y 完整的年份
%m 月份(01 - 12)
%d 一个月中的第几天(01 - 31
%H 一天中的第几个小时(24小时制,00 - 23)
%M 分钟数(00 - 59)
%S 秒(01 - 61)

具体详见:

https://www.runoob.com/python/python-date-time.html

datetime包

注:datetimetime是两个不同的类型,不能混用。

from datetime import datetime

datetime.today()

代码

t = datetime.today()  # type:datetime
print(t, type(t))
print(t.year)  # 年份
print(t.month)  # 月份

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

datetime.now()

datetime.today()基本一样,返回的是本地时间

代码


t = datetime.now()  # type:datetime
print(t,type(t))

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

datetime.utcnow()

utcnow返回的是标准(UTC)时间,上述俩返回的都是本地时间,我们是东八区

代码


t = datetime.now()
print("东八区时间:", t)
t = datetime.utcnow()  # type:datetime
print("UTC时间:", t)

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

时间戳转datetime

有时候,我们拿到的,就是时间戳,那就只能转了。

代码


# 时间戳
timestamp = time.time()
print(f"timestamp:{timestamp},type:{type(timestamp)}")
# 时间戳转datetime
t = datetime.fromtimestamp(timestamp)
print(f"t:{t},type:{type(t)}")

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

datetime -> 字符串日期(strftime)

代码

from datetime import datetime

t = datetime.now()
str_datetime = t.strftime("%Y-%m-%d %H:%M:%S")
print(f"字符串日期:{str_datetime},type:{type(str_datetime)}")

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

字符串日期 -> datetime(strptime)

代码

from datetime import datetime

str_datetime = "2020-11-29 22:05:20"
t = datetime.strptime(str_datetime, "%Y-%m-%d %H:%M:%S")
print(f"t:{t},type:{type(t)}")

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

时间加减

这才是本次的重头戏,好像只有datetime这个包,才有时间加减的。

时间加减的具体用途很多,必须多久过期什么的,多久之后提醒,都需要提前计算时间,还是很重要的。

代码


from datetime import datetime
import datetime as idatetime

t = datetime.now()
print(f"当前时间:{t}")
three_day = t + idatetime.timedelta(days=3)
print(f"三天后时间:{three_day}")

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

可以发现,这个时间确实是+成功了。

但是自带的时间加减,有个题,只能加天,不能加月,甚至年。

如果想要时间+月等,还要自己写逻辑。

​一篇文章总结一下Python库中关于时间的常见操作

datetime时间自由加减


有个包正好解决了这个问题。

安装

pip install python-dateutil

代码


from datetime import datetime
from dateutil.relativedelta import relativedelta

t = datetime.now()
print(f"当前时间:{t}")
three_time = t + relativedelta(months=3)
print(f"三个月后时间:{three_time}")
one_year = t+relativedelta(years=1)
print(f"一年后时间:{one_year}")
up_year = t+relativedelta(years=-1)
print(f"去年这个时间:{up_year}")

执行结果

​一篇文章总结一下Python库中关于时间的常见操作

用法很简单,如果想加月/年份,就写正数,如果想减,就写负数,这个方法基本上将python在操作时间上的缺点给弥补了。

总结

本篇主要讲述的是关于Python时间的相关总结,相对来说,更推荐使用datetime

需要注意的是,timedatetime是俩类型,是不能混用的。

其实最重要的是字符串时间->时间类型,这个在实际中用的非常多!

顺便还有python-dateutilrelativedelta相关方法,能够自由加减时间,算是挺方便的。

如果在操作过程中有任何问题,记得下面留言,我们看到会第一时间解决问题。

越努力,越幸运。如果觉得还不错,记得动手点赞一下哈。感谢你的观看。

最后想学习更多关于Python的知识,可以参考学习网址:http://pdcfighting.com/,点击阅读原文,可以直达噢~

**-----**------**-----**---**** End **-----**--------**-----**-****

往期精彩文章推荐:

​一篇文章总结一下Python库中关于时间的常见操作

欢迎各位大佬点击链接加入群聊【helloworld开发者社区】:https://jq.qq.com/?_wv=1027&k=mBlk6nzX进群交流IT技术热点。

点赞
收藏
评论区
推荐文章
浅梦一笑 浅梦一笑
2个月前
初学 Python 需要安装哪些软件?超级实用,小白必看!
编程这个东西是真的奇妙。对于懂得的人来说,会觉得这个工具是多么的好用、有趣,而对于小白来说,就如同大山一样。其实这个都可以理解,大家都是这样过来的。那么接下来就说一下python相关的东西吧,并说一下我对编程的理解。本人也是小白一名,如有不对的地方,还请各位大神指出01名词解释:如果在编程方面接触的比较少,那么对于软件这一块,有几个名词一定要了解,比如开发环
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
1年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Stella981 Stella981
1年前
Django之Django模板
1、问:html页面从数据库中读出DateTimeField字段时,显示的时间格式和数据库中存放的格式不一致,比如数据库字段内容为2012082616:00:00,但是页面显示的却是Aug.26,2012,4p.m.答:为了页面和数据库中显示一致,需要在页面格式化时间,需要添加<td{{dayrecord.p\_time|date:
Stella981 Stella981
1年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
1年前
QClub 太原,2014年11月15日 Global Day of Coderetreat
QClub太原,2014年11月15日GlobalDayofCoderetreat活动时间:2014年11月15日星期六,全天(9:0018:00)活动地点:高新区体育路科技街口,大豪益达402(从KK这边的巷子进去,统一这面
Wesley13 Wesley13
1年前
java常用类(2)
三、时间处理相关类Date类:计算机世界把1970年1月1号定为基准时间,每个度量单位是毫秒(1秒的千分之一),用long类型的变量表示时间。Date分配Date对象并初始化对象,以表示自从标准基准时间(称为“历元”(epoch),即1970年1月1日08:00:00GMT)以来的指定毫秒数。示例:packagecn.tanjian
Wesley13 Wesley13
1年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Wesley13 Wesley13
1年前
PHP中的NOW()函数
是否有一个PHP函数以与MySQL函数NOW()相同的格式返回日期和时间?我知道如何使用date()做到这一点,但是我问是否有一个仅用于此的函数。例如,返回:2009120100:00:001楼使用此功能:functiongetDatetimeNow(){
Wesley13 Wesley13
1年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_