python中日期处理问题总结

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’)

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用python处理日期时,如果需要借助js来处理日期,可能会遇到一些问题。其可能原因如下: 1. 语法差异:Python和JavaScript有不同的语法和语言规范,因此,在直接将js代码嵌入到Python程序时,可能会导致语法错误或者不可理解的代码。这种情况下,需要仔细检查代码语法,对不兼容的部分进行调整或者改写。 2. 日期格式不匹配:Python和JavaScript对日期处理方式和日期格式也存在差异。在将日期数据从Python传递给JavaScript时,需要确保两者之间的日期格式是一致的。可以使用日期库如moment.js或者datetime库来格式化日期,以便在不同语言之间进行交互。 3. 缺乏js环境:Python是一种解释性的编程语言,而JavaScript通常在浏览器环境下执行。如果在Python程序使用js处理日期,可能会缺乏JavaScript的运行环境。这种情况下,可以考虑使用Python的内置库或第三方库来处理日期。 4. 不兼容的函数和方法:Python和JavaScript的标准库和函数是不同的,因此,在使用js处理日期时,可能会遇到某些函数或方法在Python无法找到或无法使用的情况。这时需要查阅相关文档或参考资料,找到在Python实现类似功能的方法。 总结来说,需要结合具体情况来分析为什么无法成功使用js处理日期。可以检查代码语法、日期格式匹配、环境是否缺失以及兼容性问题等方面,逐一排查并解决问题。如果遇到较大的兼容性问题,可以考虑使用其他替代方案或者尝试使用纯Python的方式处理日期

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值