由于某些原因,我在Pandas更新日志中找不到0.17.1,将datetime系列与int值(Unix纪元)进行比较不再适用.任何人都可以解释一下,或者指向更改日志中的正确部分?
工作在0.16.2
>>> import pandas as pd
>>> import datetime
>>> d = pd.Series([datetime.datetime(2016, 1, 1), datetime.datetime(2016, 1, 1)])
>>> d
0 2016-01-01
1 2016-01-01
dtype: datetime64[ns]
>>> d.dtype
dtype('<M8[ns]')
>>> d > 10
0 True
1 True
dtype: bool
0.17.1中的错误
>>> import pandas as pd
>>> import datetime
>>> d = pd.Series([datetime.datetime(2016, 1, 1), datetime.datetime(2016, 1, 1)])
>>> d > 10
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/Users/sven/tmp/pandastest/pandas-0.17.1/lib/python2.7/site-packages/pandas/core/ops.py", line 726, in wrapper
res = na_op(values, other)
File "/Users/sven/tmp/pandastest/pandas-0.17.1/lib/python2.7/site-packages/pandas/core/ops.py", line 657, in na_op
raise TypeError("invalid type comparison")
TypeError: invalid type comparison
解决方法:
您仍然可以使用显式转换:
u_time_ns = d.apply(lambda x: x.to_datetime64().view('int64'))
u_time_ns
0 1451606400000000000
1 1451606400000000000
dtype: int64
u_time_ns > 10
0 True
1 True
dtype: bool
或者,如果您想依赖将pandas时间戳存储为datetime64 [ns]:
u_time_ns = d.view('int64')
对不起,不知道为什么会改变.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。