我有一个日期字符串的格式为“Mon Feb 15 2010”。我想更改格式为'15/02/2010'。我该怎么做呢?


当前回答

Datetime模块可以帮助你:

datetime.datetime.strptime(date_string, format1).strftime(format2)

对于具体的例子

>>> import datetime
>>> datetime.datetime.strptime('Mon Feb 15 2010', '%a %b %d %Y').strftime('%d/%m/%Y')
'15/02/2010'
>>>

其他回答

>>> from_date="Mon Feb 15 2010"
>>> import time                
>>> conv=time.strptime(from_date,"%a %b %d %Y")
>>> time.strftime("%d/%m/%Y",conv)
'15/02/2010'

您可以安装dateutil库。它的解析函数可以找出字符串的格式,而不必像使用datetime.strptime那样指定格式。

from dateutil.parser import parse
dt = parse('Mon Feb 15 2010')
print(dt)
# datetime.datetime(2010, 2, 15, 0, 0)
print(dt.strftime('%d/%m/%Y'))
# 15/02/2010

如果你不想定义输入日期格式,那么安装dateparser (pip Install dateparser)和,

from dateparser import parse
parse("Mon Feb 15 2010").strftime("%d/%m/%Y")

由于这个问题经常出现,这里有一个简单的解释。

Datetime或time模块有两个重要的功能。

Strftime -从datetime或time对象创建日期或时间的字符串表示。 Strptime -从字符串创建日期时间或时间对象。

在这两种情况下,我们都需要一个格式化字符串。它是告诉日期或时间如何在字符串中格式化的表示。

现在假设我们有一个date对象。

>>> from datetime import datetime
>>> d = datetime(2010, 2, 15)
>>> d
datetime.datetime(2010, 2, 15, 0, 0)

如果我们想从这个日期开始创建一个字符串,格式为Mon Feb 15 2010

>>> s = d.strftime('%a %b %d %y')
>>> print s
Mon Feb 15 10

假设我们想要再次将这个s转换为一个datetime对象。

>>> new_date = datetime.strptime(s, '%a %b %d %y')
>>> print new_date
2010-02-15 00:00:00

参考本文档所有关于datetime的格式化指令。

你也可以使用熊猫来实现这一点:

import pandas as pd

pd.to_datetime('Mon Feb 15 2010', format='%a %b %d %Y').strftime('%d/%m/%Y')

输出:

'15/02/2010'

你可以对不同的数据类型应用pandas方法:

import pandas as pd
import numpy as np

def reformat_date(date_string, old_format, new_format):
    return pd.to_datetime(date_string, format=old_format, errors='ignore').strftime(new_format)

date_string = 'Mon Feb 15 2010'
date_list = ['Mon Feb 15 2010', 'Wed Feb 17 2010']
date_array = np.array(date_list)
date_series = pd.Series(date_list)

old_format = '%a %b %d %Y'
new_format = '%d/%m/%Y'

print(reformat_date(date_string, old_format, new_format))
print(reformat_date(date_list, old_format, new_format).values)
print(reformat_date(date_array, old_format, new_format).values)
print(date_series.apply(lambda x: reformat_date(x, old_format, new_format)).values)

输出:

15/02/2010
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']