我正在尝试使用xlwing复制一个简单的技术分析指标。但是,列表/数据似乎无法读取Excel值。下面是代码
import pandas as pd
import datetime as dt
import numpy as np
@xw.func
def EMA(df, n):
EMA = pd.Series(pd.ewma(df['Close'], span = n, min_periods = n - 1), name = 'EMA_' + str(n))
df = df.join(EMA)
return df当我输入excel数据列表: EMA = ({1,2,3,4,5},5},TypeError:列表索引必须是整数,而不是str EMA =pd.Series(pd.ewma(df‘’Close‘,span = n,min_periods =n- 1),name = 'EMA_’+ str(n))
(专家)非常感谢您的帮助!谢谢。
发布于 2017-04-04 18:58:42
EMA()需要一个EMA和一个标量n,并且它在源DataFrame中的单独列中返回DataFrame。您正在传递一个简单的值列表,这是不应该工作的。
构造DataFrame并将值分配给Close列:
v = range(100) # use your list of values instead
df = pd.DataFrame(v, columns=['Close'])使用此DataFrame调用EMA():
EMA(df, 5)https://stackoverflow.com/questions/43204365
复制相似问题