datetime中的strptime与strftime
datetime是Python中的一个模块,其中这个模块中有一个类也叫datetime。我们对于时间和字符串格式的处理主要使用这两个函数
strptime()是将字符串格式转化成日期格式(也就是年月日时分秒),如下:
In [80]:datetime.datetime.strptime('2020-08-18 19:31:50', '%Y-%m-%d %H:%M:%S')
Out[80]: datetime.datetime(2020, 8, 18, 19, 31, 50)
调入datetime包的时候,使用from datetime import datetime
语句
这个例子中,前面输入的字符串格式的日期,使用strptime()转换的时候,也要到时分秒,如果只输入%Y-%m-%d
就会报错,同时也不能写成%Y/%m/%d
,而且其他显示星期几等参数在这个函数中不能使用。
strftime()是将时间格式转换成字符串格式,这里上面所说的strptime()中不能实现的,这里都可以实现,原因是strftime()函数输出的是字符串格式,结果会相对灵活点。
In [94]datetime.strftime(datetime.now(), '%Y/%m/%d %H:%M')
Out[94]: '2020/08/18 19:46'
In [95]datetime.strftime(datetime.now(), '%Y %H:%M')
Out[95]: '2020 19:50'
In [97]datetime.strftime(datetime.now(), '%A %H:%M')
Out[97]: 'Tuesday 19:50'
In [103]datetime.strftime(datetime.now(), '%X %H:%M')
Out[103]: '19:53:38 19:53'
strftime()中时间显示的参数如下:
%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)
%a 本地简化星期名称
%A 本地完整星期名称
%b 本地简化的月份名称
%B 本地完整的月份名称
%c 本地相应的日期表示和时间表示
%j 年内的一天(001-366)
%p 本地A.M.或P.M.的等价符
%U 一年中的星期数(00-53)星期天为星期的开始
%w 星期(0-6),星期天为星期的开始
%W 一年中的星期数(00-53)星期一为星期的开始
%x 本地相应的日期表示
%X 本地相应的时间表示
%Z 当前时区的名称
%% %号本身
datetime中时间的加减timedelta()
关于datetime中时间的加减是转换成日期格式进行加减,使用datetime模块中的timedelta来进行运算的,其与datetime中的datetime类相似,使用的时候从datetime中调入
In [107]now + timedelta(days=1)
Out[107]: datetime.datetime(2020, 8, 19, 20, 5, 12, 20683)
In [108]now + timedelta(days=1, hours=3)
Out[108]: datetime.datetime(2020, 8, 19, 23, 5, 12, 20683)
timedelta()中的参数是年月日时分秒等,且是复数形式,如timedelta(days=1, hours=3)
timedelta()还可以计算微秒和:
In [111]timedelta(hours=1.232,seconds=20.3).microseconds
Out[111]: 500000
另外:
- 1 millisecond(毫秒) = 1000 microseconds(微秒)
- 1 seconds = 1000millisecond(毫秒) = 1000000 microseconds(微秒)
- 1 minute = 60 seconds
- 1 hour = 3600 seconds
- 1 week = 7 days
datetime中最后一位就是微秒 - 时间戳