python datetime 增加月份的问题

原创
2012/08/31 09:35
阅读数 2.8W

我的主要工作是从事.net开发,记得.net中有相应的对DateTime月份加减操作。然而在学习python datetime类型的时候却发现对月份没有相应操作。 

在python中对datetime类型的操作主要涉及到两个对象,1.datetime 2.timedelta 其中后者为一个时间差对象。相当于.net中的TimeSpan类对象。

 在我的开发中需要对日期进行月份加减的过程中,我理所当然的找到了timedelta,然而发现这个类中没有对月份的参数,它的定义如下:

 class datetime.timedelta([days[, seconds[, microseconds[, milliseconds[, minutes[, hours[, weeks]]]]]]]) 于是网上找到一些解决办法: 

def add_months(dt,months):
    targetmonth=months+dt.month
    try:
        dt=dt.replace(year=dt.year+int(targetmonth/12),month=(targetmonth%12))
    except:
        dt=dt.replace(year=dt.year+int((targetmonth+1)/12),month=((targetmonth+1)%12),day=1)
        dt+=datetime.datetime.timedelta(days=-1)
    return dt

  总体的思路就是: 拿出给定时间的月份加上指定个月,超过一年在年上+1, 月份取模后余值。这里就设计到一个问题:如果8月31日加1月的话,那么就会变成9月31日,显然9月不存在31日,该方案是在异常的时候对这种情况进行了处理。(取下月的第一天,然后减去一天) 

本来已经实现了,后来无聊琢磨着这个事情,所谓的加一个月或者几个月我们想得到的是什么?因为月份不是个固定的数量,应该是这个原因python把具体的实现留给了我们把。

 +1月,我们要得到的是下月的这天,对于月末的一天,如我们距离的8月31日,如果+1月,应该得到9月31日,由于这天不存在所以我们取9月末的30号为结果。这样就出现了8月30日、8月31日+1月的结果都是9月30日的结果。(用.net的AddMonths验证结果也如此)。 

在上面给出的解决办法中,由于要抛异常,显然不是个很好的办法,下面给出几种其他办法:

 1.自己实现,没有了抛异常的部分 

def add_months(dt,months):
    month = dt.month - 1 + months
    year = dt.year + month / 12
    month = month % 12 + 1
    day = min(dt.day,calendar.monthrange(year,month)[1])
    return dt.replace(year=year, month=month, day=day)

 2.利用其他人实现的日期操作包, 如dateutil

展开阅读全文
打赏
0
2 收藏
分享
加载中
这个和闰年无关吗,calender自动处理了?
2015/03/31 15:45
回复
举报
更多评论
打赏
1 评论
2 收藏
0
分享
返回顶部
顶部