在Python(GAE)中将字符串转换为datetime对象?

Converting string to datetime object in Python (GAE)?

我是Python的新手,但我需要将项目从PHP迁移到Python(在GAE环境中运行),我需要将所有数据从一个数据库移动到GAE的一个。
挑战在于将数据字符串写入datetime对象。
日期存储为字符串,使用PHP的模式"l dS of F Y(h:i:s A)"创建
所以每个日期都是这样的:
2005年7月31日星期日(02:05:50 PM)

我已经查看了Python文档,我可以看到datetime.strptime可以完成这项工作,但是......
它没有"th","rd"和"st"结尾的参数。 并且可能还有其他一些问题。

你有什么建议我的?
我可以使用RegExp并删除所有不必要的垃圾,或者有没有办法直接从这样的字符串创建一个datetime对象?

先感谢您。


如果你可以使用带有GAE的dateutil,那么

1
2
3
In [70]: import dateutil.parser as parser
In [71]: parser.parse('Sunday 31st of July 2005 ( 02:05:50 PM )',fuzzy=True)
Out[71]: datetime.datetime(2005, 7, 31, 14, 5, 50)

否则,您将不得不依赖re将日期字符串操作为strptime可以解析的格式。

1
2
In [89]: datetime.datetime.strptime(re.sub(r'\w+ (\d+)\w+ of(.+)\s+\( (.+) \)',r'\1 \2 \3','Sunday 31st of July 2005 ( 02:05:50 PM )'),'%d %B %Y %I:%M:%S %p')
Out[89]: datetime.datetime(2005, 7, 31, 14, 5, 50)