我得到了大量需要读入数据库的日期时间表示。我正在使用 Python(因为它很摇滚)。这些字符串的格式非常糟糕,它们不精确到秒,没有说明时区,并且小时没有前导 0。所以它们看起来更像这样:
April 29, 2013, 7:52 p.m.
April 30, 2013, 4 p.m.
您会注意到,如果在 4:00 到 4:01 之间发生某些事情,它也会减少分钟数(呃)。无论如何,尝试用 time.strptime 解析这些,但是文档声明小时必须是十进制数字 [01:12](或 [01:24])。由于没有用 0 填充,我想知道是否还有其他东西可以传递给 strptime 以接受小时数而不以 0 开头;或者如果我应该尝试拆分,然后填充字符串;或使用其他构造日期时间对象的方法。
此外,它看起来不像 strptime 接受 AM/PM 作为“AM”或“PM”,所以我也必须更正它。. .
请注意,我不能只批量处理这些字符串。我从一个外部应用程序一次一次地接收它们,该应用程序有时使用格式良好的 Unix 纪元时间戳,但偶尔使用这种格式。即时处理它们是唯一的选择。
我正在使用 Python 2.7 并导入了一些 Python 3 功能。
from __future__ import (print_function, unicode_literals)