1、获取当前日期
from datetime import datetime
print(datetime.now())
2、获取当前日期的年、月、日
print(datetime.now().year) #年
print(datetime.now().month) #月
print(datetime.now().day) #日
print(datetime.now().hour) #时
print(datetime.now().minute) #分
print(datetime.now().second) #秒
3、创建日期对象
(1)使用datetime() 类创建。datetime() 类还接受时间和时区(小时、分钟、秒、微秒、tzone)的参数,不过它们是可选的,默认值为 0,(时区默认为 None)。
print(datetime(2023,5,1))
print(datetime(2023,5,1,12,1,10))
(2)使用strptime()方法将日期字符串转换为datetime对象。使用format 参数来指定返回字符串的格式。
date1='2023-01-22'
d1=datetime.strptime(date1,'%Y-%m-%d')
print(d1)
5、日期格式转换
(1)日期型转成字符型
①str()方法。直接转换
a=datetime(2023,5,1,12,1,10)
print(type(a))
b=str(a)
print(b)
print(type(b))
②strftime()方法,可定义字符串格式。
a=datetime(2023,5,1,12,1,10)
print(type(a))
b=a.strftime('%Y-%B-%d')
print(b)
print(type(b))
③pandas中日期型转成字符型
df[‘date_str’] = df[‘date’].dt.strftime(‘%Y-%m-%d’)
(2)字符型转成日期型
①strptime()方法:使用方法见上
②parse()方法
from dateutil.parser import parse
date1='23-01-22'
d1=parse(date1)
print(d1)
③pandas中字符型转成日期型
df[‘createtime’]=pd.to_datetime(df[‘createtime’])
df[‘createtime’] = np.array(df[‘createtime’], dtype=‘datetime64’)
5、计算两个时间的时间差
①计算月份/年份差
from datetime import datetime
def get_month_difference(date1, date2):
d1 = datetime.strptime(date1, "%Y-%m-%d")
d2 = datetime.strptime(date2, "%Y-%m-%d")
if d2.day>=d1.day:
month_diff = (d2.year - d1.year) * 12 + (d2.month - d1.month)
else:
month_diff = (d2.year - d1.year) * 12 + (d2.month - d1.month-1)
return month_diff
# 示例用法
date1 = "2021-01-15"
date2 = "2023-05-01"
months = get_month_difference(date1, date2)
print(months) # 输出:16
②计算天数差
d1='2023-01-01'
d2='2023-06-08'
date1=datetime.strptime(d1,'%Y-%m-%d')
date2=datetime.strptime(d2,'%Y-%m-%d')
days=date2-date1
print(days)
print(days.days)
③计算分钟差
d1=datetime(2023,1,5,10,5,10)
d2=datetime(2023,5,1,12,1,10)
a=d2-d1
#直接计算
print(a.total_seconds()/60)
#换算
print(a.days*24*60+a.seconds/60)
两个datetime格式做差返回datetime.timedelta格式,包含天数、秒、微秒三个等级如果要获取小时、分钟则需要进行换算。
④pandas中计算时间差
##年月日计算
import pandas as pd
dirc={'姓名':['张三','李四','王五','赵六'],'年龄':[34,34,23,32],'入职时间':['2012-05-11','2015-03-11','2018-06-01','2020-09-21']}
df=pd.DataFrame(dirc)
df['入职时间']=pd.to_datetime(df['入职时间'])
#.dt访问日期时间属性
now=datetime.now()
df['入职年限']=(now.year-df['入职时间'].dt.year)+round((now.month-df['入职时间'].dt.month)/12,2)
##时分秒计算
import pandas as pd
dirc={'姓名':['张三','李四','王五','赵六'],'年龄':[34,34,23,32],
'申请时间':['2012-05-11 12:01:15','2015-03-11 09:13:11','2018-06-01 10:21:15','2020-09-21 17:56:15'],
'结束时间':['2012-05-11 12:40:15','2015-04-01 10:12:18','2018-06-03 10:01:15','2020-09-21 20:00:15']}
df=pd.DataFrame(dirc)
df['申请时间']=pd.to_datetime(df['申请时间'])
df['结束时间']=pd.to_datetime(df['结束时间'])
df['审批时长']=(df['结束时间']-df['申请时间']).dt.total_seconds()/60
6、时间偏移
①timedelta:只支持天、秒、微秒单位的时间运算
from datetime import timedelta
date=datetime(2019,1,23,2,34,34)
#往后推一天
print(date+timedelta(days=1))
#往前推6分钟
print(date-timedelta(seconds=360))
②offset :可以直接实现天、小时、分钟单位的时间偏移
from pandas.tseries.offsets import Day,Hour,Minute
date=datetime(2019,1,23,2,34,34)
#往后推一天
print(date+Day(1))
#往后推一小时
print(date+Hour(1))
#往后推10分钟
print(date+Minute(10))
③pandas中的时间偏移计算
(1)DateOffset(年月周时天分秒)
pd.DateOffset是pandas库中的一个日期偏移量(Date Offset)类,用于进行日期的加法操作。它提供了一组预定义的偏移量,例如年、季度、月、周、日等,以及用于自定义偏移量的选项。使用pd.DateOffset的常见用法是通过将其与pd.Timestamp对象进行加法操作,以获取指定日期加上偏移量后的结果。
import pandas as pd
dirc={'姓名':['张三','李四','王五','赵六'],'年龄':[34,34,23,32],
'申请时间':['2012-05-11 12:01:15','2015-03-11 09:13:11','2018-06-01 10:21:15','2020-09-21 17:56:15'],
'结束时间':['2012-05-11 12:40:15','2015-04-01 10:12:18','2018-06-03 10:01:15','2020-09-21 20:00:15']}
df=pd.DataFrame(dirc)
df['申请时间']=pd.to_datetime(df['申请时间'])
#增加1年5个月2周3天1分钟30秒
df['时间']=df['申请时间']+pd.DateOffset(years=1,months=5,weeks=2,days=3,minutes=1,seconds=30)
(2)Timedelta(周天时分秒)
pd.Timedelta是pandas库中的一个时间间隔(Timedelta)类,用于表示时间间隔。它提供了一组用于处理时间间隔的方法,例如加法、减法、乘法等。使用pd.Timedelta的常见用法是通过将其与pd.Timestamp对象进行加法操作,以获取时间间隔加上指定日期时间后的结果。
import pandas as pd
dirc={'姓名':['张三','李四','王五','赵六'],'年龄':[34,34,23,32],
'申请时间':['2012-05-11 12:01:15','2015-03-11 09:13:11','2018-06-01 10:21:15','2020-09-21 17:56:15'],
'结束时间':['2012-05-11 12:40:15','2015-04-01 10:12:18','2018-06-03 10:01:15','2020-09-21 20:00:15']}
df=pd.DataFrame(dirc)
df['申请时间']=pd.to_datetime(df['申请时间'])
#增加2周3天1分钟30秒
df['时间']=df['申请时间']+pd.Timedelta(weeks=2,days=3,minutes=1,seconds=30)
7、转换成时区时
import pytz
date=datetime(2023,1,5,10,5,10)
aware_date=pytz.timezone('Asia/Shanghai').localize(date)
print(aware_date)
8、零时区转换为东八区
df_all[‘createtime’]=df_all[‘createtime’].dt.tz_convert(‘Asia/Shanghai’)