Python - 时间数据不匹配格式

Python - Time data not match format

我有以下格式的字符串时间

2016-12-10T13:54:15.294

我正在使用以下方法来格式化时间:

time.strptime(ts, '%b %d %H:%M:%S %Y')

抛出错误:
time data did not match format: data=2016-12-10T13:54:15.294 fmt=%a %b %d %H:%M:%S %Y

我哪里出错了?

我认为您在字符串中指定的日期格式不正确。这应该有效:

import datetime
a = '2016-12-10T13:54:15.294'
b= datetime.datetime.strptime(a,'%Y-%m-%dT%H:%M:%S.%f')
print b

您需要先按格式解析字符串,然后按您想要的方式打印出来。

>>> import datetime
>>> ts = "2016-12-10T13:54:15.294"
>>> parsed = datetime.datetime.strptime(ts, '%Y-%m-%dT%H:%M:%S.%f')
>>> parsed
datetime.datetime(2016, 12, 10, 13, 54, 15, 294000)
>>> parsed.strftime('%b %d %H:%M:%S %Y')
'Dec 10 13:54:15 2016'

错误并没有错,格式字符串甚至不接近您要解析的字符串。

您有 {year}-{month}-{day}T{hour}:{minute}:{second}.{milliseconds} 但试图用 {weekday name} {month name} {day} {hour}:{minute}:{second} {year} 解析它。您是从某处复制的吗?

According to the documentation,您的格式字符串应该更像 %Y-%m-%dT%H:%M:%S.%f.

>>> time.strptime('2016-12-10T13:54:15.294', '%Y-%m-%dT%H:%M:%S.%f')
time.struct_time(tm_year=2016, tm_mon=12, tm_mday=10, tm_hour=13, tm_min=54, tm_sec=15, tm_wday=5, tm_yday=345, tm_isdst=-1)

您的格式字符串不正确。

您可以使用日期对象的 strftime 方法检查格式字符串。例如:

d = datetime.datetime.now()
print(d.strftime('%Y-%d-%mT%H:%M:%S'))

输出:

Dec 16 11:02:46 2016

但是你有以下格式的字符串 2016-12-10T13:54:15.294,所以你只需要更改 format 字符串:

print(time.strptime(ts, '%Y-%d-%mT%H:%M:%S.%f'))

输出:

time.struct_time(tm_year=2016, tm_mon=10, tm_mday=12, tm_hour=13, tm_min=54, tm_sec=15, tm_wday=2, tm_yday=286, tm_isdst=-1)