我改后的代码如下,希望有助于找出问题所在.我在下面的语句中使用了自己的公式 Set Formula = marketdata.STKINDI("RU13","SQ","MAADX()",0,5) '调用上期所RU13合约的日线自定义指标
'使用PLE语言做为信号,VBA进行测评
'PEL语言代码:
'公式名:MATEST
'MA1:=MA(CLOSE,5);
'MA2:=MA(CLOSE,15);
'
'开多:CROSS(MA1,MA2);
'平多:CROSS(MA2,MA1);
'输入选项
InitalCapital=20
'起始资金XX万
startdate="1998-1-1"
'测试起始日期
finishdate="2008-1-1"
'测试结束日期
'以下开始正式测试
Testreport.StartAndInit '开始测评系统的准备工作
Testreport.InitCash=InitalCapital*10000 '初始资金由万转为元
Set Formula = marketdata.STKINDI("RU13","SQ","MAADX()",0,5) '调用上期所RU13合约的日线自定义指标
Set HistroyData = Formula.ParentGrid.GetHistoryData '直接得到公式区的数据对象,提高运行效率
for i = 0 to 4
'将msgout与之前的数据隔开,便于观察
application.MsgOut "
"
next
application.MsgOut "HistoryData:"&cstr(HistroyData.count)
application.MsgOut "Formula.DataSize:"&Formula.DataSize
application.MsgOut "Formula.GetBufDateData(0):"&Formula.GetBufDateData(0)
application.MsgOut "Formula.GetBufDateData(Formula.DataSize-1):"&Formula.GetBufDateData(Formula.DataSize-1)
'查找在Formula中的起始日期序列号
'确定起始日期在数组中的序列号
if Formula.GetBufDateData(0)> cdate(startdate) then
'如果数据列的起始日期晚于我设定的开始日期,则说明数据不足,从已有数据序列的第一个值开始测试
application.MsgOut"测试数据不足,请检查起始日期或者更改'工具>选项>维护>内存保留'"
BeginDataNum=0
else
'如果我设定的开始数据晚于数据起始日期,则需要查找从何时开始测试
i = 0
while (i<= HistroyData.Count-1) and (Formula.GetBufDateData(i) < cdate(startdate))
i = i+1
wend
BeginDataNum=i
end if
application.MsgOut "BeginDataNum:"&BeginDataNum
application.MsgOut "Formula.GetBufDateData(BeginDataNum):"&Formula.GetBufDateData(BeginDataNum)
'看看哪一天是起始日期
'确定结束日期在数组中的序列号
if Formula.GetBufDateData(Formula.DataSize-1)< cdate(finishdate) then
'如果数据列的起始日期晚于我设定的开始日期,则说明数据不足,从已有数据序列的第一个值开始测试
application.MsgOut"测试数据不足,请检查结束日期是否正确"
FinishDataNum=Formula.DataSize-1
else
'如果我设定的开始数据晚于数据起始日期,则需要查找从何时开始测试
i = 0
while (i<= HistroyData.Count-1) and (Formula.GetBufDateData(i) < cdate(finishdate))
i = i+1
wend
FinishDataNum=i-1
end if
application.MsgOut "FinishDataNum:"&FinishDataNum
application.MsgOut "Formula.GetBufDateData(FinishDataNum):"&Formula.GetBufDateData(FinishDataNum)
'看看哪一天是结束日期
If TestReport.AddTestStock(HistroyData,"RU13","SQ",0) < 1 Then '向测试报告系统添加一个新测试品种
MsgBox "请正确添加品种"
End if
'下面的代码控制循环测试
'使用PEL策略的信号进行交易
For i = BeginDataNum to FinishDataNum
if i= BeginDataNum then
application.MsgOut "(i=BeginDataNum):
"&Formula.GetBufDateData(i)
end if
if i= FinishDataNum then
application.MsgOut "(i=FinishDataNum ):
"&Formula.GetBufDateData(i)
end if
if Formula.GetBufData("开多条件",i) = 1 Then '开多
TestReport.Buy 1, HistroyData.Close(i)
End if
if Formula.GetBufData("平多条件",i) = 1 And TestReport.Holding > 0 Then '平多
TestReport.Sell 0, HistroyData.Close(i)
End if
if Formula.GetBufData("开空条件",i) = 1 Then '开多
TestReport.Buyshort 1, HistroyData.Close(i)
End if
if Formula.GetBufData("平空条件",i) = 1 And TestReport.Holding < 0 Then '平多
TestReport.Sellshort 0, HistroyData.Close(i)
End if
'显示测试时当前的资产
'Application.msgout TestReport.ASSET
'为步进下一个数据做准备
TestReport.StepIt i
Next
'测试完毕显示测试报告
Testreport.ShowReport
set data = Nothing'对象使用完毕后释放对象