python - 在没有使用构造函数的子类或辅助函数的情况下更改 datetime.date 的日期或月份

标签 python date datetime calendar

我收到各种格式的日期或日期的一部分,然后将它们输入 datetime.date格式,我想调整月份字段或日期字段而不调用构造函数来生成一个全新的 datetime.date对象。

数据可以是以下任何一种:

'2012.01.01'
'194311'
'1865/08/30'
'1701'
 ... etc

对于未指定的日期,我想将它们推迟到 1 月 1 日、提供的月份的第一天、提供的月份的月底或 12 月 31 日。必须提供年份并且不会更改.

dateutil.parser.parse很好地处理所有这些,除了它用当前月份和/或日期填充缺少的月份和/或日期的约定:

In [11]: dateutil.parser.parse('2012/04')
Out[11]: datetime.datetime(2012, 4, 10, 0, 0)

In [12]: dateutil.parser.parse('1865')
Out[12]: datetime.datetime(1865, 2, 10, 0, 0)

In [13]: dateutil.parser.parse('1920.03.27')
Out[13]: datetime.datetime(1920, 3, 27, 0, 0)

进入datetime.datetime后格式,我可以调用 datetime函数 date有效地转换为 datetime.date , 所以那部分是微不足道的。

我想避免的是编写一个必须经历调用构造函数的痛苦的辅助函数,如下所示:

def adjust_to_jan1(date_str):
    temp = dateutil.parser.parse(date_str).date()
    return datetime.date(temp.year, 1, 1)

def adjust_to_month_end(date_str):
    import calendar
    temp = dateutil.parser.parse(date_str).date()
    last_day = calendar.monthrange(temp.year, temp.month)
    return datetime.date(temp.year, temp.month, last_day)

def adjust_to_last_weekdat(date_str):
    import calendar
    temp = dateutil.parser.parse(date_str).date()
    last_weekday = max([elem for x in calendar.monthcalendar(temp.year, 
                                                             temp.month) 
                        for elem in x[0:5]])
    return datetime.date(temp.year, temp.month, last_weekday)

由于我经常以交互方式处理这些数据,因此一直定义这些类型的函数变得很痛苦。它变得更加复杂:上周在某些任意国家/地区组中不是假期......最后一个工作日,但如果年份在某一年之前,它可以是最后一个星期六......

我想做的只是声明我想要的改变,例如:

some_date = datetime.date(2012, 1, 20)
some_date.day = 1

但这是不允许的。

我可以继承 datetime但是我不得不担心我的子类不会造成任何损害,以及它是否可以移植给使用来自交互式工作的一些脚本的其他人。

任何其他解决方案将不胜感激。

如果您认为没有比子类化或编写大量这些辅助函数更好的方法,那很好,但我更愿意为任何建议留下评论和答案与此不同——而不是得到很多回复说“这看起来不错”之类的。

最佳答案

datetime.date 对象是不可变的,但它们确实有一个 .replace() method做你想做的事:

somedate = somedate.replace(day=1)

该方法返回一个新的对象,其中交换了所需的值。

为了完整起见,还有datetime.datetime.replace()datetime.time.replace()方法。

关于python - 在没有使用构造函数的子类或辅助函数的情况下更改 datetime.date 的日期或月份,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21683188/

相关文章:

java - 在java中比较两个字符串与Date

php - 如何在 mysql 中更改 one day plus 的时间?

python - 计算每 5 行特定列的平均值,并选择 pandas 数据框中另一列的最后一个数据(第五个)

mysql SELECT * WHERE 日期 + 7 天 >= $今天

Python - QRCode 错误 "No module named ' 图像'"

javascript - getHours() 返回不正确的值

php - 如何检查mysql中是否存在数据时间?

C# 将 yyyymmdd 转换为日期时间

python - 在 C 中嵌入 Python - .py 文件中的语法错误第 1 行

python - 根据条件 pandas 数据框列删除字符串