常用方法
1.time.sleep(secs) (线程)推迟指定的时间运行。单位为秒。 2.time.time() 获取当前时间戳
表达时间的三种方式:
(1) 时间戳(timestamp)
时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量
(2) 格式化的字符串(Format Srting)
%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 当前时区的名称
%% %号本身
python中时间日期格式化符号:
(3) 元组(struct_time)
struct_time元组共有9个元素共九个元素:(年,月,日,时,分,秒,一年中第几周,一年中第几天等)
索引(Index) | 属性(Attribute) | 值(Values) |
---|---|---|
0 | tm_year(年) | 比如2011 |
1 | tm_mon(月) | 1 - 12 |
2 | tm_mday(日) | 1 - 31 |
3 | tm_hour(时) | 0 - 23 |
4 | tm_min(分) | 0 - 59 |
5 | tm_sec(秒) | 0 - 60 |
6 | tm_wday(weekday) | 0 - 6(0表示周一) |
7 | tm_yday(一年中的第几天) | 1 - 366 |
8 | tm_isdst(是否是夏令时) | 默认为0 |
#导入时间模块
>>>import time
#时间戳
>>>time.time()
1548222022.0479286
#时间字符串
>>>time.strftime("%Y-%m-%d %X")
'2019-01-23 13:40:48'
>>>time.strftime("%Y-%m-%d %H-%M-%S")
'2019-01-23 13-41-11'
#时间元组:localtime将一个时间戳转换为当前时区的struct_time
time.localtime()
time.struct_time(tm_year=2019, tm_mon=1, tm_mday=23, tm_hour=13, tm_min=41, tm_sec=33, tm_wday=2, tm_yday=23, tm_isdst=0)
小结:时间戳是计算机能够识别的时间;时间字符串是人能够看懂的时间;元组则是用来操作时间的
几种格式之间的转换
元组(struct_time);格式化的字符串(Format Srting);时间戳(timestamp)
#时间戳-->结构化时间
#time.gmtime(时间戳) #UTC时间,与英国伦敦当地时间一致 #time.localtime(时间戳) #当地时间。例如我们现在在北京执行这个方法:与UTC时间相差8小时,UTC时间+8小时 = 北京时间
>>> time.gmtime(1548222645)
time.struct_time(tm_year=2019, tm_mon=1, tm_mday=23, TM_HOUR=5, tm_min=50, tm_sec=45, tm_wday=2, tm_yday=23, tm_isdst=0)
>>> time.localtime(1548222645)
time.struct_time(tm_year=2019, tm_mon=1, tm_mday=23, TM_HOUR=13, tm_min=50, tm_sec=45, tm_wday=2, tm_yday=23, tm_isdst=0)
#结构化时间-->时间戳
#time.mktime(结构化时间)
>>> time_tuple = time.localtime(1548222645)
>>> time.mktime(time_tuple)
1548222645.0
#结构化时间-->字符串时间
#time.strftime("格式定义","结构化时间") 结构化时间参数若不传,则显示当前时间
>>> time.strftime("%Y-%m-%d %X")
'2019-01-23 14:56:13'
>>> time.strftime("%Y-%m-%d",time.localtime(1548222645))
'2019-01-23'
#字符串时间-->结构化时间
#time.strptime(时间字符串,字符串对应格式)
>>> time.strptime("2019-01-23","%Y-%m-%d")
time.struct_time(tm_year=2019, tm_mon=1, tm_mday=23, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=2, tm_yday=23, tm_isdst=-1)
>>> time.strptime("2019*01*23","%Y*%m*%d")
time.struct_time(tm_year=2019, tm_mon=1, tm_mday=23, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=2, tm_yday=23, tm_isdst=-1)
#结构化时间 --> %a %b %d %H:%M:%S %Y串
#time.asctime(结构化时间) 如果不传参数,直接返回当前时间的格式化串
>>> time.asctime()
'Wed Jan 23 14:59:40 2019'
>>> time.asctime(time.localtime(1548222645))
'Wed Jan 23 13:50:45 2019'
#时间戳 --> %a %b %d %H:%M:%S %Y串
#time.ctime(时间戳) 如果不传参数,直接返回当前时间的格式化串
>>> time.ctime()
'Wed Jan 23 15:00:29 2019'
>>> time.ctime(1548222645)
'Wed Jan 23 13:50:45 2019'
import time
true_time=time.mktime(time.strptime('2019-01-11 08:30:00','%Y-%m-%d %H:%M:%S'))
time_now=time.mktime(time.strptime('2019-01-23 11:00:00','%Y-%m-%d %H:%M:%S'))
dif_time=time_now-true_time
struct_time=time.gmtime(dif_time)
print('过去了%d年%d月%d天%d小时%d分钟%d秒'%(struct_time.tm_year-1970,struct_time.tm_mon-1,
struct_time.tm_mday-1,struct_time.tm_hour,
struct_time.tm_min,struct_time.tm_sec))
计算时间差
» 本文链接地址:https://blog.mydns.vip/1398.html
最新评论
我的站目前每天120个IP,其中刷的是100个。 不知道为什么升级到4H8G5M的标准服务器还是偶尔会崩,CPU占满,但是内存一般这种时候只占50%左右,这是为什么呢?max_children我也设
麻烦发下检测工具
让我下载