繁体   English   中英

如何更改日期时间格式?

[英]How to change datetime format?

我在我的熊猫数据帧的格式如下给出时间戳df2015-03-09 11:09:05.0 如何将它们转换为这种格式2015-03-09T11:09:05.0 (即以T分隔)?

df["dt"] = df["dt"].apply(lambda x: ???)

你快到了。 您正在寻找isoformat。 https://docs.python.org/3.6/library/datetime.html#datetime.date.isoformat

import pandas as pd
df = pd.DataFrame({'dt':pd.to_datetime(['2015-03-09 11:09:05.0'])})

df["dt"] = df["dt"].apply(lambda x: x.isoformat())

df

返回

            dt
0  2015-03-09T11:09:05

您可以通过向isoformat()插入参数来更改T(默认值),例如df["dt"] = df["dt"].apply(lambda x: x.isoformat(" "))

使用strftime和自定义格式:

df = pd.DataFrame({'dt':pd.to_datetime(['2015-03-09 11:09:05.0'])})
print (df)

df["dt"] = df["dt"].dt.strftime('%Y-%m-%dT%H:%M:%S.%f')
print (df)
                           dt
0  2015-03-09T11:09:05.000000

或者转换为string ,按whitespace拆分并按T加入:

df["dt"] = df["dt"].astype(str).str.split().str.join('T')

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM