gpt4 book ai didi

python - 如何将格式为 'dd/mm/yyyy %H:%M' 的 Pandas 数据框日期列转换为 'yyyy/mm/dd %H:%M'

转载 作者:太空宇宙 更新时间:2023-11-03 13:57:55 24 4
gpt4 key购买 nike

我的数据框格式为“dd/mm/yyyy %H:%M”。

Date                Price
29/10/2018 19:30 163.09
29/10/2018 20:00 211.95
29/10/2018 20:30 205.86
29/10/2018 21:00 201.39
29/10/2018 21:30 126.68
29/10/2018 22:00 112.36
29/10/2018 22:30 120.94

我希望这个数据框的格式为“yyyy/mm/dd %H:%M”,如下所示。

Date                Price
2018/29/10 19:30 163.09
2018/29/10 20:00 211.95
2018/29/10 20:30 205.86
2018/29/10 21:00 201.39
2018/29/10 21:30 126.68
2018/29/10 22:00 112.36
2018/29/10 22:30 120.94

我试过了df['Date'] = pd.to_datetime(df['Date]) 但它给出的结果如下,这不是我要找的东西

Date                   Price
2018-29-10 19:30:00 163.09
2018-29-10 20:00:00 211.95
2018-29-10 20:30:00 205.86
2018-29-10 21:00:00 201.39

最佳答案

使用strftime用于将日期时间转换为字符串格式:

df['Date'] = pd.to_datetime(df['Date']).dt.strftime('%Y/%m/%d %H:%M')

print (df)
Date Price
0 2018/10/29 19:30 163.09
1 2018/10/29 20:00 211.95
2 2018/10/29 20:30 205.86
3 2018/10/29 21:00 201.39
4 2018/10/29 21:30 126.68
5 2018/10/29 22:00 112.36
6 2018/10/29 22:30 120.94

print (type(df.loc[0, 'Date']))
<class 'str'>

print (df['Date'].dtype)
object

因此,如果想使用 datetimeslike 函数,仅使用 to_datetime,格式为 YYYY-MM-DD HH:MM:SS:

df['Date'] = pd.to_datetime(df['Date'])
print (df)
Date Price
0 2018-10-29 19:30:00 163.09
1 2018-10-29 20:00:00 211.95
2 2018-10-29 20:30:00 205.86
3 2018-10-29 21:00:00 201.39
4 2018-10-29 21:30:00 126.68
5 2018-10-29 22:00:00 112.36
6 2018-10-29 22:30:00 120.94

print (type(df.loc[0, 'Date']))
<class 'pandas._libs.tslibs.timestamps.Timestamp'>

print (df['Date'].dtype)
datetime64[ns]

关于python - 如何将格式为 'dd/mm/yyyy %H:%M' 的 Pandas 数据框日期列转换为 'yyyy/mm/dd %H:%M',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53062336/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com