![](/img/trans.png)
[英]python - convert multiple string datetimes format into a specific date format
[英]Convert date into a specific format in python irrespective of the input format is
我有一个问题陈述将日期转换为特定格式。 但是,输入可以是任何格式。 例如,
输入 | 期望输出 |
---|---|
2020/11/20 | 2020-11-20 |
20201120 | 2020-11-20 |
20202011 | 2020-11-20 |
11/20/2020 | 2020-11-20 |
20202011月 | 2020-11-20 |
我能够使用 Dateutil 包解决年、月和日期之间存在分隔符的位置。 但它无法解决没有明确分隔符的地方。
有没有办法解决这个问题?
我认为没有一种简单的方法可以普遍解析不遵循标准格式的日期。 您必须指定写入日期的格式以供解析,您可以使用strptime
轻松完成(有关日期时间格式的参考,请参见此处)。
像dateutil
这样的包也很有帮助。 但是,您应该查看接受的日期格式。 一般来说, dateutil
更方便,但strptime
为您提供了更多的控制权和解析更多日期格式的能力。
您提到的五个示例中有四个可以使用dateutil
进行解析,如下所示:
from dateutil import parser
parser.parse("2020/11/20") # Output: datetime.datetime(2020, 11, 20, 0, 0)
parser.parse("11/20/2020") # Output: datetime.datetime(2020, 11, 20, 0, 0)
对于另外两个示例,需要dayfirst
和yearfirst
参数才能让dateutil
正确解析它们:
parser.parse("20201120", yearfirst=True)
parser.parse("20202011", yearfirst=True, dayfirst=True)
# Output for both: datetime.datetime(2020, 11, 20, 0, 0)
最后,我不知道使用dateutil
解析日期"202020Nov"
方法; 但是,它可以使用strptime
解析如下:
from datetime import datetime
datetime.strptime("202020Nov", "%Y%d%b")
# Output: datetime.datetime(2020, 11, 20, 0, 0)
一切顺利。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.