将“pandas.tslib.Timestamp”对象转换为“datetime”`

2024-05-15 08:47:35 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试将pandas.tslib.Timestamp对象转换为datetimedf['orig_iss_dt']pandas.tslib.Timestamp对象。我使用了答案here来尝试这样做,但是发现print(type(origination))仍然返回相同的类型。

df['orig_iss_dt'] = df['orig_iss_dt'].apply(lambda x: datetime.date(x.year,x.month,x.day)) 

for (i, row) in df:
    origination = row.orig_iss_dt
    print(type(origination))

Tags: 对象答案pandasdfdatetimeheretypedt
1条回答
网友
1楼 · 发布于 2024-05-15 08:47:35

将pandas Timestamp转换为datetime.datetime的最简单方法是使用to_pydatetime方法。这可以直接在Timestamp上调用,也可以在序列上调用:

In [15]: s = pd.Series(pd.date_range('2012-01-01', periods=3))

In [16]: s
Out[16]:
0   2012-01-01
1   2012-01-02
2   2012-01-03
dtype: datetime64[ns]

In [17]: s[0]
Out[17]: Timestamp('2012-01-01 00:00:00')

In [18]: s.dt.to_pydatetime()
Out[18]:
array([datetime.datetime(2012, 1, 1, 0, 0),
       datetime.datetime(2012, 1, 2, 0, 0),
       datetime.datetime(2012, 1, 3, 0, 0)], dtype=object)

但请注意,这通常是不需要的,因为Timestampdatetime.datetime的一个子类。

相关问题 更多 >