ps : Python 时间处理模块还有 calendar 模块html
UTC+8
print(type(time.time()))
, 返回的是float类型import time print(time.time()) # 1608256754.2573004 print(type(time.time())) # <class 'float'>
import time print(time.strftime("%Y-%m-%d %H:%M:%S %p")) # 2020-12-18 10:25:16 AM
符号 | 说明 |
---|---|
%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 | 当前时区的名称 |
%% | %号自己 |
import time ⛅localtime( ) print(time.localtime()) # 本地时区元组(struct_time) '''输出 time.struct_time(tm_year=2020, tm_mon=12, tm_mday=18, tm_hour=8, tm_min=45, tm_sec=9, tm_wday=4, tm_yday=353, tm_isdst=0)\ ''' print(type(time.localtime())) # <class 'time.struct_time'> print(time.localtime()[3]) # 8 ⛅gmtime( ) print(time.gmtime()) # UTC时区元组(struct_time) '''输出 time.struct_time(tm_year=2020, tm_mon=12, tm_mday=18, tm_hour=0, tm_min=45, tm_sec=9, tm_wday=4, tm_yday=353, tm_isdst=0) ''' print(type(time.gmtime())) # <class 'time.struct_time'> print(time.gmtime()[0]) # 2020
索引(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 - 61 |
6 | tm_wday(weekday) | 0 - 6(0表示周日) |
7 | tm_yday(一年中的第几天) | 1 - 366 |
8 | tm_isdst(是不是夏令时) | 默认为-1 |
格式化的字符串时间
与时间戳
之间的转换都是以结构化的时间
做为中转站来进行操做的python
结构化时间
与时间戳
之间的转化函数
time.mktime([结构化时间])
: "struct_time" 转换 "timestamp"time.localtime([时间戳])
: "timestamp" 转换 "struct_time" 本地时区time.gmtime([时间戳])
: "timestamp" 转换 "struct_time" UTC时区time.gmtime([time.time()])
import time ⛅"struct_time" 转换 "timestamp" print(time.mktime(time.localtime())) # 1608259357.0 print(time.mktime(time.gmtime())) # 1608259357.0 ⛅"timestamp" 转换 "struct_time" print(time.localtime(456465.4685)) # 返回的是"struct_time"本地时区元组 print(time.localtime(time.time())) # 里面不填时间戳默认就是当前时间戳"time.time()" print(time.gmtime(456465.4685)) # 返回的是"struct_time"UTC时区元组 print(time.gmtime(time.time()))
结构化时间
与格式化字符串时间
之间的转换
time.strftime([时间格式],[结构化时间])
: "struct_time" 转换 "format time"time.strptime([格式化的字符串时间],[时间格式])
: "format time" 转换 "struct_time"import time ⛅"struct_time" 转换 "format time" print(time.strftime("%Y/%m/%d %X %p")) # 2020/12/18 10:53:28 AM (%X 表明时分秒) print(time.strftime("%Y-%m-%d %H:%M:%S %p")) # 2020-12-18 10:53:28 AM res = time.strftime("%Y-%m-%d %H:%M:%S %p",time.localtime()) print(res) # 2020-12-18 10:58:22 AM (第二个参数填写的是"结构化时间", 默认就是当前时间的结构化时间) res2 = time.strftime("%Y-%m-%d %H:%M:%S %p",time.gmtime(16545.5163)) print(res2) # 1970-01-01 04:35:45 AM ⛅"format time" 转换 "struct_time" print(time.strptime('2020-12-18 10:58:22 AM','%Y-%m-%d %H:%M:%S %p')) # 第一个参数是格式化字符串时间,第二个参数是对应的格式,必须一一对应,否则报错, 获得的是struct_time元组 ''' time.struct_time(tm_year=2020, tm_mon=12, tm_mday=18, tm_hour=10, tm_min=58, tm_sec=22, tm_wday=4, tm_yday=353, tm_isdst=-1) ''' print(time.strptime('1970-01-01 04:35:45 AM','%Y-%m-%d %H:%M:%S %p')) ''' time.struct_time(tm_year=1970, tm_mon=1, tm_mday=1, tm_hour=4, tm_min=35, tm_sec=45, tm_wday=3, tm_yday=1, tm_isdst=-1) '''
格式化的字符串时间
与时间戳之间
的转换⛅"format time" 与 "timestamp" 转换 res = '2020-12-18 11:03:12 AM' # 当前时间字符串 struct_time = time.strptime(res,'%Y-%m-%d %H:%M:%S %p') # 先转成格式化字符, 格式必须一一对应 timestamp = time.mktime(struct_time) # 再转成时间戳 print(timestamp) # 1608260592.0 ⛅时间加减, 以当前时间戳为起始来计算 res2 = timestamp + 24*3600 # 一天以后时间戳 print(res2) # 1608346992.0 res3 = timestamp - 24*3600 # 一天以前时间戳 print(res3) # 1608174192.0 ⛅将加减以后的"时间戳"转换成"format time" struct_time = time.localtime(res2) # 先转换成格式化时间 format_time = time.strftime("%Y-%m-%d %X %p",struct_time) # 再转换成格式化时间字符串 print(format_time) # 2020-12-19 11:03:12 AM (一天以后的时间) struct_time = time.localtime(res3) format_time = time.strftime("%Y-%m-%d %X %p",struct_time) print(format_time) # 2020-12-17 11:03:12 AM (一天以前的时间)
import time def sleep(n): time.sleep(n) print(f"睡了{n}秒以后才打印的我") sleep(3) # 睡了3秒以后才打印的我
ps : 作爬虫以及破解帐号的时候, 程序须要模拟人类的行动来进行操做, 人类不可能有机器那么快的速度, 因此通常放一些"sleep"来模拟人类的慢动做, 以避免被检测为机器而被掐断链接spa
ps2 : 推荐一篇博客 : 以故事话爬虫code
time.localtime()
import time print(time.asctime()) # Fri Dec 18 18:22:04 2020 print(time.asctime(time.localtime())) # Fri Dec 18 18:22:04 2020
time.time()
time.asctime(time.localtime(n))
, "n" 表示秒import time print(time.ctime()) # Fri Dec 18 18:26:37 2020 print(time.ctime(time.time())) # Fri Dec 18 18:26:37 2020 print(time.ctime(5456161.56456)) # Thu Mar 5 11:36:01 1970
ps : 在 Linux 系统上这种格式比较常见, 等同于: time.strftime('%b %a %d %X %Y')
orm
datetime.now( )
: 统计当前时间import datetime print(datetime.datetime.now()) # 2020-12-18 20:56:58.262592 (本地时间) print(datetime.datetime.utcnow()) # 2020-12-18 12:56:58.262592 (世界标准时间)
date.fromtimestamp( )
: 将时间戳直接转成格式化字符串的時間import datetime print(datetime.date.fromtimestamp(5465564.564)) # 1970-03-05 print(datetime.date.fromtimestamp(time.time())) # 2020-12-18
timedelta( )
: 统计时间间隔与时间加减运算 (没有年份单位的计算)import datetime print(datetime.datetime.now() + datetime.timedelta(-2)) # 两天前,不写关键字默认"day" print(datetime.datetime.now() + datetime.timedelta(days=-2)) # 两天前 print(datetime.datetime.now() + datetime.timedelta(weeks=3)) # 三星期后 print(datetime.datetime.now() + datetime.timedelta(hours=-3)) # 三小时前 print(datetime.datetime.now() + datetime.timedelta(seconds=10)) # 十秒后 print(datetime.datetime.now() + datetime.timedelta(minutes=10)) # 十分钟后 print(datetime.datetime.now() + datetime.timedelta(minutes=10, seconds=30)) # 十分钟30秒后
replace( )
: 时间替换import datetime now_time = datetime.datetime.now() print(now_time) # 2020-12-18 20:53:34.602813 print(now_time.replace(minute=00,hour=00,second=00)) # 2020-12-18 00:00:00.267086 print(now_time.replace(day=11,month=11,year=1111)) # 1111-11-11 20:53:34.602813