【问题标题】:Convert "unknown format" strings to datetime objects?将“未知格式”字符串转换为日期时间对象?
【发布时间】:2012-11-06 20:05:55
【问题描述】:

这可能是一个非常基本的问题,但在阅读文档后我仍然无法弄清楚如何去做......

我在 Python 中有两个字符串,其中包含 未知格式 的日期。我不知道它们采用什么格式,但我知道它们都是有效的日期时间表达式。例如,其中一个可能是 ISO 格式,另一个可能是其他格式。

我只需要能够比较日期。将字符串转换为适当的日期时间对象以便进行比较的正确方法是什么?

谢谢!

【问题讨论】:

  • 我更新了标题;问题不是“比较日期时间字符串”,而是“将字符串转换为可比较的值”。

标签: python date date-conversion


【解决方案1】:

dateutil module 有一个日期解析器,可以解析多种格式的日期字符串。

例如,

In [13]: import dateutil.parser as parser

In [14]: parser.parse("19970902T090000")
Out[14]: datetime.datetime(1997, 9, 2, 9, 0)

In [15]: import datetime as dt

In [16]: now = dt.datetime.now()

In [17]: now.isoformat()
Out[18]: '2012-11-06T15:08:51.393631'

In [19]: parser.parse('2012-11-06T15:08:51.393631')
Out[19]: datetime.datetime(2012, 11, 6, 15, 8, 51, 393631)

In [20]: parser.parse('November 6, 2012')
Out[20]: datetime.datetime(2012, 11, 6, 0, 0)

请注意,某些日期时间字符串可能不明确:例如,10-09-2003 可能表示 10 月 9 日或 9 月 10 日。 dateutildayfirstyearfirst 之类的参数来处理这个问题:

In [21]: parser.parse("10-09-2003")
Out[21]: datetime.datetime(2003, 10, 9, 0, 0)

In [22]: parser.parse("10-09-2003", dayfirst = True)
Out[22]: datetime.datetime(2003, 9, 10, 0, 0)

In [23]: parser.parse("10-09-03", yearfirst = True)
Out[23]: datetime.datetime(2010, 9, 3, 0, 0)

【讨论】:

    猜你喜欢
    • 2016-09-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-08-10
    • 1970-01-01
    相关资源
    最近更新 更多