首页 > 解决方案 > 如何将大于 59 的熊猫数据框的分钟列转换为正确的日期时间?

问题描述

我有一个有 2 列的 pandas 数据框:第一列是分钟,第二列是秒。它看起来像这样:

     min   s
0      0   0
1      0   1
2      0   2
3      0   3
4      0   4
5      0   5
6      0   6
7      0   7
8      0   8
9      0   9
10     0  10
11     0  11
12     0  12

我可以通过以下方式将其转换为日期时间:

l = []
for MinSec in list(zip(df['min'],df['s'])):
    l.append(':'.join(map(str,MinSec)))

pd.to_datetime(pd.Series(l), format='%M:%S')

但是,当 min 列达到 59 时,它会继续向上计数(60、61、62 等)。这会引发错误:

ValueError: time data '60:0' does not match format '%M:%S' (match)

我将如何处理此错误并将上述两列熊猫数据框成功加入日期时间?

标签: pythonpandasdataframedatetime

解决方案


计算总秒数:

df['total_second']=60.*df['min']+df['s'] 

然后您可以将其转换为 Datetime :

pd.to_datetime(df['total_second'], unit='s')

推荐阅读