我想知道是否有一种有效的方法来获得行子集下面和上面的X个行数。我已经在下面创建了一个基本的实现,但是我相信还有更好的方法。我关心的子集是buyindex,它是具有buy信号的行的索引。我想在sellindex的上面和下面获取几行,以验证我的算法是否正常工作。我怎样才能有效地做到这一点?我的路似乎迂回。在
buyindex = list(data2[data2['buy'] == True].index)
print buyindex [71, 102, 103, 179, 505, 506, 607]
buyindex1 = map(lambda x: x + 1, buyindex)
buyindex2 = map(lambda x: x - 1, buyindex)
buyindex3 = map(lambda x: x - 2, buyindex)
buyindex4 = map(lambda x: x + 2, buyindex)
buyindex.extend(buyindex1)
buyindex.extend(buyindex2)
buyindex.extend(buyindex3)
buyindex.extend(buyindex4)
buyindex.sort()
data2.iloc[buyindex]
更新-这是数据的结构。 我有“买入”的指数,但我基本上想得到高于买入和低于买入的几个指数。在
^{pr2}$更新:我根据选择的答案创建了一个通用函数。如果你认为这可以提高效率,请告诉我。在
def get_test_index(df, column, numbers):
"""
builds an test index based on a range of numbers above and below the a specific index you want.
df = dataframe to build off of
column = the column that is important to you. for instance, 'buy', or 'sell'
numbers = how many above and below you want of the important index
"""
idx_l = list(df[df[column] == True].index)
for i in range(numbers)[1:]:
idxpos = data2[column].shift(i).fillna(False)
idxpos = list(df[idxpos].index)
idx_l.extend(idxpos)
idxneg = data2[column].shift(-i).fillna(False)
idxneg = list(df[idxneg].index)
idx_l.extend(idxneg)
#print idx_l
return sorted(idx_l)
这将是一个非常有效的方法
如果你想要一个任意索引器的函数,只需创建一个列表 您想要的并传递给
^{pr2}$.iloc
你可能想要独一无二的
您可以使用
shift
和|
运算符;例如,对于+/-2天,您可以这样做相关问题 更多 >
编程相关推荐