在Pandas时间序列中每天查询相同的时间值

时间:2015-09-17 19:29:52

标签: python pandas datetime dataframe

我想每天从每天有24小时分钟数据的多日数据框中获取07h00值。

import numpy as np
import pandas as pd

aframe = pd.DataFrame([np.arange(10000), np.arange(10000) * 2]).T
aframe.index = pd.date_range("2015-09-01", periods = 10000, freq = "1min")

aframe.head()
Out[174]: 
                     0  1
2015-09-01 00:00:00  0  0
2015-09-01 00:01:00  1  2
2015-09-01 00:02:00  2  4
2015-09-01 00:03:00  3  6
2015-09-01 00:04:00  4  8

aframe.tail()
Out[175]: 
                        0      1
2015-09-07 22:35:00  9995  19990
2015-09-07 22:36:00  9996  19992
2015-09-07 22:37:00  9997  19994
2015-09-07 22:38:00  9998  19996
2015-09-07 22:39:00  9999  19998

在这10万行的DataFrame中,我将如何尽可能高效地每天获取7am值?假设我可能不得不为非常大的tick数据库执行此操作,因此我非常重视速度和低内存使用率。

我知道我可以使用以下字符串编制索引:

aframe.ix["2015-09-02 07:00:00"]
Out[176]: 
0    1860
1    3720
Name: 2015-09-02 07:00:00, dtype: int64

但我需要的基本上是一个通配符样式查询,例如

aframe.ix["* 07:00:00"]

1 个答案:

答案 0 :(得分:7)

您可以使用indexer_at_time

>>> locs = aframe.index.indexer_at_time('7:00:00')
>>> aframe.iloc[locs]
                        0      1
2015-09-01 07:00:00   420    840
2015-09-02 07:00:00  1860   3720
2015-09-03 07:00:00  3300   6600
2015-09-04 07:00:00  4740   9480
2015-09-05 07:00:00  6180  12360
2015-09-06 07:00:00  7620  15240
2015-09-07 07:00:00  9060  18120

如果您需要选择介于两个特定时间之间的所有索引,还有indexer_between_time

这两种方法都返回所需值的整数位置;可以使用iloc获取Series或DataFrame的相应行,如上所示。