我正在尝试使用以下代码将 Python 中的日期格式“31-Dec-09”转换为“2009-12-31”:df = ['19-Jan-19', '4-Jan-19'] f = [datetime.datetime.strptime(x,'%d-%mmm-%y').strftime('%Y-%m-%d') for x in df]print(f)得到以下错误:time data '9-Jan-19' does not match format '%d-%mmm-%y'我在某处读到匹配两位数的年份“00”需要小写的 y 而不是大写的 y。无论哪种方式,我都遇到了同样的错误,所以我想还有其他问题。有什么帮助吗?
2 回答
大话西游666
TA贡献1817条经验 获得超14个赞
您的%y和%Y模式很好,问题是您%mmm在这里使用了。该datetime.strptime()方法的模式都是单字母图案,并且%mmm作为被视为%m图案后跟两个文字m字符。%m匹配数字月份(1 或 2 位数字,零填充可选)。所以19-1mm-19会匹配,但19-Jan-19不会因为月份不是数字并且m缺少两个文字字符。
要使用的正确模式在'%d-%b-%y'这里,其中%b匹配缩写的月份名称。
演示:
>>> import datetime
>>> df = ['19-Jan-19', '4-Jan-19']
>>> [datetime.datetime.strptime(x,'%d-%b-%y').strftime('%Y-%m-%d') for x in df]
['2019-01-19', '2019-01-04']
添加回答
举报
0/150
提交
取消