Python 自定义日期时间(?) 格式处理



假设我有一个字符串,表示一周中天数的时间:

例如"52300",表示一周的第 5 天(星期五),23 小时 00 分钟。

如何将其解析为时间或日期时间对象以添加 timedelta(hours=3) 并将其恢复为这种奇怪的格式?预期输出为"60200"字符串。

我试过:

tow_str = '52300'
tow = datetime.datetime.strptime(tow_str, "%w%H%M") + datetime.timedelta(hours=3)
print(tow.strftime("%w%H%M"))
返回"20200"

而不是"60200"

使用 %w 准确解析日期需要包含日期本身,否则日期设置为 1900-01-01:

>>> import datetime
>>> tow_str = '52300'
>>> datetime.datetime.strptime(tow_str, "%w%H%M")
datetime.datetime(1900, 1, 1, 23, 0)

而且在格式化回字符串时,您总是会得到1

>>> datetime.datetime.strptime(tow_str, "%w%H%M").strftime("%w%H%M")
'12300'

没有日期,%w就毫无意义。

您可以根据今天的日期生成工作日的日期,并且只分析时间:

def nearest_date_for_weekday(weekday):
    today = datetime.date.today()
    return today + datetime.timedelta(days=weekday - today.weekday())
parsed_date = datetime.datetime.combine(
    nearest_date_for_weekday(int(tow_str[0])), 
    datetime.datetime.strptime(tow_str[1:], '%H%M').time())
print parsed_date.strftime('%w%H%M')

因此,这将生成一个完整的datetime对象,因此格式化回字符串会为%w提供有意义的值。

最新更新