关闭页面特效
0|1在python中通常有这几种方式来表示时间:
- 时间戳
- 格式化的时间字符串
- 元组(struct_time)共九个元素
0|1时间类型:
- UTC(Coordinated Universal Time,世界协调时)亦即格林威治天文时间,世界标准时间。在中国为UTC+8
- DST(Daylight Saving Time)即夏令时
- 时间戳(timestamp)的方式:通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量,我们运行
type(time.time())
,返回的是float类型。返回时间戳方式的函数主要有time(),clock()等。 - 元组(struct_time)方式:struct_time元组共有9个元素,返回struct_time的函数主要有gmtime(),localtime(),strptime()。下面列出这种方式元组中的几个元素:
- print(time.clock()) #返回处理器时间,3.3开始已废弃 , 改成了time.process_time()测量处理器运算时间,不包括sleep时间,不稳定,mac上测不出来
- print(time.altzone) #返回与utc时间的时间差,以秒计算
- print(time.asctime()) #返回时间格式"Fri Aug 19 11:14:16 2016",
- print(time.localtime()) #返回本地时间 的struct time对象格式
- print(time.gmtime(time.time()-800000)) #返回utc时间的struc时间对象格式
- print(time.asctime(time.localtime())) #返回时间格式"Fri Aug 19 11:14:16 2016",
- print(time.ctime()) #返回Fri Aug 19 12:38:29 2016 格式, 同上
0|1日期字符串 转成 时间戳
- string_2_struct = time.strptime("2016/05/22","%Y/%m/%d") #将日期字符串转成
struct
时间对象格式 - struct_2_stamp = time.mktime(string_2_struct) #将struct时间对象转成时间戳
0|1将时间戳转为字符串格式
- print(time.gmtime(time.time()-86640)) #将utc时间戳转换成struct_time格式
- print(time.strftime("%Y-%m-%d %H:%M:%S",time.gmtime()) ) #将utc struct_time格式转成指定的字符串格式
0|1时间加减
0|1c_time = datetime.datetime.now()
0|1print(c_time.replace(minute=3,hour=2)) #时间替换
格式参照
索引 (Index) | 属性 (Attribute) | 值 (Values) |
---|---|---|
0 | tm_year (年) | 比如 2020 |
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 (是否是夏令时) | 默认为 -1 |
0|1time模块中常用的几个函数:
- time.localtime([secs]):将一个时间戳转换为当前时区的struct_time。secs参数未提供,则以当前时间为准。
0|1time.gmtime([secs]):和localtime()方法类似,gmtime()方法是将一个时间戳转换为UTC时区(0时区)的struct_time。
0|1time.time():返回当前时间的时间戳。
0|1time.mktime(t):将一个struct_time转化为时间戳。
0|1time.sleep(secs):线程推迟指定的时间运行。单位为秒。
0|1time.clock():这个需要注意,在不同的系统上含义不同。在UNIX系统上,它返回的是“进程时间”,它是用秒表示的浮点数(时间戳)。而在WINDOWS中,第一次调用,返回的是进程运行的实际时间。而第二次之后的调用是自第一次调用以后到现在的运行时间。(实际上是以WIN32上QueryPerformanceCounter()为基础,它比毫秒表示更为精确)
0|1time.asctime([t]):把一个表示时间的元组或者struct_time表示为这种形式:'Sun Jun 20 23:21:05 1993'。如果没有参数,将会将time.localtime()作为参数传入。
0|1time.ctime([secs]):把一个时间戳(按秒计算的浮点数)转化为time.asctime()的形式。如果参数未给或者为None的时候,将会默认time.time()为参数。它的作用相当于time.asctime(time.localtime(secs))。
0|1time.strftime(format[, t]):把一个代表时间的元组或者struct_time(如由
0|1time.localtime()和time.gmtime()返回)转化为格式化的时间字符串。如果t未指定,将传入time.localtime()。如果元组中任何一个元素越界,ValueError的错误将会被抛出。
格式 | 含义 | 备注 |
---|---|---|
%a | 本地(locale)简化星期名称 | |
%A | 本地完整星期名称 | |
%b | 本地简化月份名称 | |
%B | 本地完整月份名称 | |
%c | 本地相应的日期和时间表示 | |
%d | 一个月中的第几天(01 - 31) | |
%H | 一天中的第几个小时(24小时制,00 - 23) | |
%I | 第几个小时(12小时制,01 - 12) | |
%j | 一年中的第几天(001 - 366) | |
%m | 月份(01 - 12) | |
%M | 分钟数(00 - 59) | |
%p | 本地am或者pm的相应符 | 一 |
%S | 秒(01 - 61) | 二 |
%U | 一年中的星期数。(00 - 53星期天是一个星期的开始。)第一个星期天之前的所有天数都放在第0周。 | 三 |
%w | 一个星期中的第几天(0 - 6,0是星期天) | 三 |
%W | 和%U基本相同,不同的是%W以星期一为一个星期的开始。 | |
%x | 本地相应日期 | |
%X | 本地相应时间 | |
%y | 去掉世纪的年份(00 - 99) | |
%Y | 完整的年份 | |
%Z | 时区的名字(如果不存在为空字符) | |
%% | ‘%’字符 |
0|1time.strptime(string[, format]):把一个格式化时间字符串转化为struct_time。实际上它和strftime()是逆操作。
0|1它们之间的转化如图所示:
__EOF__