如何解决以两种不同的格式解析日期时间 - Python
根据项目是否超过一周,日期采用以下格式:
不到一周,由星期几和时间组成:
date1 = "Monday 21:14"
一个多星期了,只是日期:
date2 = "5 Apr '21"
我将它们作为字符串读入,需要将它们解析为一致的时间戳。
我尝试过的一种方法是:
from dateutil.parser import parse
parse(date1)
# output: datetime.datetime(2021,4,23,22,18)
parse(date2)
# output: datetime.datetime(2021,5,0)
使用 dateutil
包,我可以轻松解析 date2
,但它为我提供了 date1
的前瞻性星期五,而不是前一个星期五。
您建议我如何解析这两个日期,但不知道会收到哪一个?我可以指示解析器采用上一个工作日(即上一个星期五)
非常感谢
解决方法
为解析器设置默认值可能会起作用。由于您希望取前一个工作日以防未定义月份中的日期,因此您可以使用一周前的今天的日期。
例如:
from datetime import datetime,timedelta
from dateutil import parser
date1 = "Monday 21:14"
date2 = "5 Apr '21"
# reference = date of today one week ago (as datetime object):
ref_date = datetime(*datetime.now().timetuple()[:3]) - timedelta(7)
for d in (date1,date2):
print(parser.parse(d,default=ref_date))
# 2021-04-12 21:14:00
# 2021-04-05 00:00:00
请注意,今天是 2021-4-19 星期一,但此代码为您提供了上一个星期一,2021-4-12。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。