无法存储格式为%Y.%m。%d

时间:2019-08-19 10:16:33

标签: python pandas date-formatting

我正在尝试将数据帧存储为csv。我希望日期列以格式'%Y.%m.%d'存储。由于某种原因,数据似乎总是以'%Y-%m-%d'格式存储。

import pandas as pd
from datetime import date

DATE_FORMAT = '%Y.%m.%d'

df = pd.DataFrame({'Col': [1.5, 2.3, 3.5],
                   'Date_Col': [date(2019, 1, 1), date(2019, 2, 1), date(2019, 3, 1)]})

df.to_csv('df.csv', index=False, decimal=',', sep=';', date_format=DATE_FORMAT)

生成的csv文件如下所示

Col;Date_Col
1,5;2019-01-01
2,3;2019-02-01
3,5;2019-03-01

我已检查DATE_FORMAT是有效格式

print(date(2019, 2, 1).strftime(DATE_FORMAT))
2019.02.01

这是怎么回事,如何获得正确的输出?我知道可以将所有日期列都转换为字符串,但是我宁愿不使用这种方法,因为我需要在脚本的其他位置使用数据框。

1 个答案:

答案 0 :(得分:1)

如果值是datetimes,而不是python对象日期,则解决方案有效:

Python日期在熊猫(熊猫0.24+)中可以使用了,但是仍然存在一些局限性/错误。

df['Date_Col'] = pd.to_datetime(df['Date_Col'])
a = df.to_csv(index=False, decimal=',', sep=';', date_format=DATE_FORMAT)
print (a)
Col;Date_Col
1,5;2019.01.01
2,3;2019.02.01
3,5;2019.03.01