日期转化
存储文件时,经常会遇到在文件名中加入时间的做法。在清洗当前数据时候,可能也会有清洗超过1天的旧数据。这些都需要用到时间的日期转化还有比较。一些基础的日期格式如下:
%a星期的简写。如 星期三为Web
%A星期的全写。如 星期三为Wednesday
%b月份的简写。如4月份为Apr
%B月份的全写。如4月份为April
%c: 日期时间的字符串表示。(如: 04/07/10 10:43:39)
%d: 日在这个月中的天数(是这个月的第几天)
%f: 微秒(范围[0,999999])
%H: 小时(24小时制,[0, 23])
%I: 小时(12小时制,[0, 11])
%j: 日在年中的天数 [001,366](是当年的第几天)
%m: 月份([01,12])
%M: 分钟([00,59])
%p: AM或者PM
%S: 秒(范围为[00,61],为什么不是[00, 59],参考python手册~_~)
%U: 周在当年的周数当年的第几周),星期天作为周的第一天
%w: 今天在这周的天数,范围为[0, 6],6表示星期天
%W: 周在当年的周数(是当年的第几周),星期一作为周的第一天
%x: 日期字符串(如:04/07/10)
%X: 时间字符串(如:10:43:39)
%y: 2个数字表示的年份
%Y: 4个数字表示的年份
%z: 与utc时间的间隔 (如果是本地时间,返回空字符串)
%Z: 时区名称(如果是本地时间,返回空字符串)
%%: %% => %
- 时间转成字符串
import datetime
# datatime->string
time=datetime.datetime.now().strftime("%Y-%m-%d-%H-%M-%S")
- 字符串转时间
import datetime
# string->datatime
y=datetime.datetime.strptime(tmp_name,"%Y-%m-%d-%H-%M-%S")
或者
from datetime import datetime
# string->datatime
y=datetime.strptime(tmp_name,"%Y-%m-%d-%H-%M-%S")
假如
import datetime
# string->datatime
y=datetime.strptime(tmp_name,"%Y-%m-%d-%H-%M-%S")
会出现AttributeError: ‘datetime’ module has no attribute 'strptime’的错误。
比较
两个时间相减,用datatime比较时间大小,时间的差值可以转为天,分钟等:
#超过1天
z = datetime.datetime.now()
y=datetime.datetime.strptime(tmp,"%Y-%m-%d-%H-%M-%S")
diff_day=(z-y).days
if diff_day>=1:
process
#转成分钟
diff_second=(z-y).seconds