本文介绍了过滤负时间增量的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
考虑一个持有timedelta64[ns]
的系列,该系列在两个事件A和B之间的时间差处进行测量:
Consider a series holding timedelta64[ns]
that measures at the time difference between two events A and B:
> time_deltas
499900 -1 days +23:45:13
499916 -1 days +23:50:57
499917 00:03:27
499919 00:17:45
499920 00:16:56
499921 -1 days +23:59:26
499922 00:16:34
499923 00:15:46
499928 00:12:56
499929 00:05:54
...
499970 00:00:48
499971 -1 days +23:58:32
dtype: timedelta64[ns]
如何确定负增量? (例如A发生在B之前).
How can I identify negative deltas? (e.g. A happening before B).
这不起作用:
> time_deltas[time_deltas<0]
TypeError: invalid type comparison
还请考虑以下事项:
# Negative time delta example:
> time_deltas.iloc[-1]
Timedelta('-1 days +23:58:32')
# Values seem to have integer representation in ns
> time_deltas.iloc[-1].value
-88000000000
# Positive time delta example:
> time_deltas.iloc[-2]
Timedelta('0 days 00:00:48')
# Again, values seem to have integer representation in ns
> time_deltas.iloc[-1].value
48000000000
但是然后:
# Trying to use the internal representation fails
> time_deltas.apply(lambda x: x.value>0)
AttributeError: 'numpy.timedelta64' object has no attribute 'value'
# Same with
> time_deltas.apply(lambda x: x['value']>0)
IndexError: invalid index to scalar variable.
推荐答案
将其与pd.Timedelta(0)
进行比较:
In [60]: time_deltas = pd.to_timedelta(np.random.randint(-10**6, 10**6, size=10))
In [61]: time_deltas
Out[61]:
TimedeltaIndex([ '00:00:00.000809', '-1 days +23:59:59.999034',
'-1 days +23:59:59.999456', '-1 days +23:59:59.999156',
'-1 days +23:59:59.999053', '-1 days +23:59:59.999723',
'-1 days +23:59:59.999523', '00:00:00.000349',
'00:00:00.000051', '00:00:00.000774'],
dtype='timedelta64[ns]', freq=None)
In [62]: time_deltas < pd.Timedelta(0)
Out[62]: array([False, True, True, True, True, True, True, False, False, False], dtype=bool)
这篇关于过滤负时间增量的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!