我需要找到最近5天的移动平均高度(abs(Close-Open))。我每天都有OHLC数据。一个简单的解决方案是首先创建一列“高度”,然后使用滚动功能计算5天移动平均值。但这使我的代码效率低下。我需要找到移动平均高度而无需创建新列。
我的数据如下所示,预期输出在“平均高度”列中:
Date Open High Low Close Average Height
01-01-2018 1763.95 1763.95 1725 1731.35
02-01-2018 1736.2 1745.8 1725 1743.2
03-01-2018 1741.1 1780 1740.1 1774.6
04-01-2018 1779.95 1808 1770 1801.35
05-01-2018 1801.1 1820.4 1795.6 1809.95 20.67
08-01-2018 1816 1827.95 1800 1825 15.95
09-01-2018 1823 1835 1793.9 1812.05 16.74
10-01-2018 1812.05 1823 1801.4 1816.55 10.94
11-01-2018 1825 1825.05 1798.55 1802.1 11.24
12-01-2018 1805 1820 1794 1804.95 9.48
15-01-2018 1809.9 1834.45 1792.45 1830 11.7
16-01-2018 1835 1857.45 1826.1 1850.25 12.56
17-01-2018 1850 1852.45 1826.2 1840.5 13.56
18-01-2018 1840.5 1852 1823.5 1839 9.28
19-01-2018 1828.25 1836.35 1811 1829.5 9.52
我正在使用的当前代码如下片段:
df['Avg Height'] = df[abs(df['Close'] - df['Open'])].rolling(window = 5).mean()
但是,当然,由于我遇到错误,它看起来不正确。
答案 0 :(得分:0)
正确答案如下:
df['Avg Height'] = abs(df['Close'] - df['Open']).rolling(window = 5).mean()