转换Pandas时间序列:UNIX epoch到datetime

use*_*984 1 python datetime pandas

我想将以下一系列UNIX纪元转换为常规日期时间对象:

>> val = pd.Series(["1440643875", "1440644191", "1440645638", "1440998720"])
>> val
0    1440643875
1    1440644191
2    1440645638
3    1440998720
Name: obj, dtype: object
Run Code Online (Sandbox Code Playgroud)

似乎有两种方法可以做到这一点.首先是:

>> pd.to_datetime(val, unit='s')
ValueError: year is out of range
Run Code Online (Sandbox Code Playgroud)

第二个:

val.astype("datetime64[s]")
TypeError: Cannot parse "1445124547" as unit 's' using casting rule 'same_kind'
Run Code Online (Sandbox Code Playgroud)

这里似乎有什么问题?

我还尝试使用"在线时代计算器"工具检查这些时间戳,并给出合理的答案.

use*_*984 7

问题是元素是字符串,而不是整数.显然,pd.to_datetime()从字符串转换为日期时间不够智能.

我的解决方案是:

>> val.astype('int').astype("datetime64[s]")
0   2015-08-27 02:51:15
1   2015-08-27 02:56:31
2   2015-08-27 03:20:38
3   2015-08-31 05:25:20
dtype: datetime64[ns]
Run Code Online (Sandbox Code Playgroud)