如何解决无论输入格式如何,将日期转换为python中的特定格式
我有一个问题陈述将日期转换为特定格式。但是,输入可以是任何格式。 例如,
输入 | Desired_output |
---|---|
2020/11/20 | 2020-11-20 |
20201120 | 2020-11-20 |
20202011 | 2020-11-20 |
11/20/2020 | 2020-11-20 |
202020 年 11 月 | 2020-11-20 |
我能够使用 Dateutil 包解决年、月和日期之间存在分隔符的位置。但是不能解决没有明确分隔符的地方。
有什么办法可以解决这个问题吗?
解决方法
我认为没有一种简单的方法可以普遍解析不遵循 standard formats 的日期。您必须指定写入日期的格式以供解析,您可以使用 strptime
轻松完成此操作(有关日期时间格式的参考,请参阅 here)。
像 dateutil
这样的包也很有帮助。但是,您应该查看 accepted date formats。一般来说,dateutil
更方便,但 strptime
为您提供了更多的控制权和解析更多日期格式的能力。
您提到的五个示例中有四个可以使用 dateutil
进行解析,如下所示:
from dateutil import parser
parser.parse("2020/11/20") # Output: datetime.datetime(2020,11,20,0)
parser.parse("11/20/2020") # Output: datetime.datetime(2020,0)
对于另外两个示例,需要 dayfirst
and yearfirst
arguments 才能让 dateutil
正确解析它们:
parser.parse("20201120",yearfirst=True)
parser.parse("20202011",yearfirst=True,dayfirst=True)
# Output for both: datetime.datetime(2020,0)
最后,我不知道使用 "202020Nov"
解析日期 dateutil
的方法;但是,它可以使用 strptime
解析如下:
from datetime import datetime
datetime.strptime("202020Nov","%Y%d%b")
# Output: datetime.datetime(2020,0)
一切顺利。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。