我有2个问题:
我尝试了以下操作:
import locale
locale.setlocale(locale.LC_ALL, 'es_ES.utf8')
from datetime import datetime as dt
df['date'] = dt.strptime(df['date'], '%b%d%Y')
df['date'] = df['date'].strftime('%Y-%m-%d')
但出现以下错误:
Error: unsupported locale setting
答案 0 :(得分:2)
认为问题在于所使用的语言环境。另外,请检查格式。
import locale
locale.setlocale(locale.LC_ALL,'es_ES.UTF-8')
from datetime import datetime as dt
datetime_object = dt.strptime('20100812', '%Y%m%d')
datetime_object
输出:
datetime.datetime(2010, 8, 12, 0, 0)
让我知道这是否可以解决您的问题。
再试几个例子。
# read a spanish datetime format
datetime_object = dt.strptime('martes 12 julio 2016', '%A %d %B %Y')
print(datetime_object.strftime("%B"))
print(datetime_object)
# Change the locale to swede and print the month
locale.setlocale(locale.LC_TIME, "sv_SE")
print(datetime_object.strftime("%B"))
输出:
julio
2016-07-12 00:00:00
Juli
经过编辑以包含您想要的特定详细信息:
import locale
locale.setlocale(locale.LC_ALL,'es_ES.UTF-8')
from datetime import datetime as dt
datetime_object = dt.strptime('ago122010', '%b%d%Y')
locale.setlocale(locale.LC_ALL,'en_US.UTF-8')
print(datetime_object.strftime("%Y-%m-%d"))
输出
2010-08-12