做astype('datetime64 [ns]')时发生错误

问题描述 投票:0回答:2

主题有两行。第一列是时间。

11:46:36 ......
12:0:4.......

我想做的是

Subject['Time'] = Subject['Time'].astype('datetime64[ns]')
Subject['Time']=Subject['Time'].dt.time

第一行效果很好,它给了我

2020-05-18 11:46:36

但是当我想对第二行执行此操作时,会出现以下错误:

OutOfBoundsDatetime: Out of bounds nanosecond timestamp: 1-01-01 12:00:04

我知道熊猫以纳秒分辨率表示时间戳,因此可以使用限于584年左右的64位整数来表示时间跨度。

[当我执行Subject['Time'].dtype时,只是给了我dtype('O')

python pandas datetime timedelta
2个回答
0
投票
对于没有“日期”部分的数据,

datetime不是适当的数据类型。您可能想改用timedelta

pd.to_timedelta(Subject["Time"])
#0   11:46:36
#1   12:00:04
#Name: Time, dtype: timedelta64[ns]

0
投票

您可以结合使用datetime和timedelta来添加自定义日期,例如

import pandas as pd

df = pd.DataFrame({'Time': ['11:46:36', '12:0:4']})

# to datetime object; add a custom date, e.g. 2020-05-18:
df['Time'] = pd.to_datetime('2020-05-18') + pd.to_timedelta(df['Time'])
# df['Time']
# 0   2020-05-18 11:46:36
# 1   2020-05-18 12:00:04
# Name: Time, dtype: datetime64[ns]
© www.soinside.com 2019 - 2024. All rights reserved.