![](/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.