欢迎使用金字塔普通技术服务论坛,您可以在相关区域发表技术支持贴。
我司技术服务人员将优先处理 VIP客服论坛 服务贴,普通区问题处理速度慢,请耐心等待。谢谢您对我们的支持与理解。


金字塔客服中心 - 专业程序化交易软件提供商金字塔软件高级功能研发区 → 建议:HistoryData类返回的是数组

   

欢迎使用金字塔普通技术服务论坛,您可以在相关区域发表技术支持贴。
我司技术服务人员将优先处理 VIP客服论坛 服务贴,普通区问题处理速度慢,请耐心等待。谢谢您对我们的支持与理解。    


  共有3341人关注过本帖平板打印复制链接

主题:建议:HistoryData类返回的是数组

帅哥哟,离线,有人找我吗?
pel46585
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:论坛游侠 帖子:167 积分:661 威望:0 精华:1 注册:2009/12/25 23:43:24
建议:HistoryData类返回的是数组  发帖心情 Post By:2013/5/21 20:37:43 [只看该作者]

大家都知道,当运算量大时,VB比C代码的运行速度要慢得多。而金字塔是对VBA开放的对象。这样,如果大量数据操作时,会造成软件当机的现象。

我不清楚具体的Histordata,ReportData,Table等等等等对象工作原理,但我想它大约是一个函数,以HistoryData为例

Set History = marketdata.GetHistoryData("rb00","sq",5)

For i=1 to 10
    x=History.Close(i)'这里我感觉是每读一个数,都需要运行一下金字塔的HistoryData函数。

'这个函数里大约对某个文件要打开,计算,再关闭文件,本身效率已经很低了,这个函数。

'如果是再用VB来反复打开这个函数。速度更慢。如果运行10000次,可能这个金字塔就要当机了。

Next

以EXCEL为例吧,如果是一个单元格一个单元的格的给数组赋值,读几万个数字,就要几秒种了。但EXCEL提供了直接将单元格赋值给数组的功能。比如x=range("A1:A65536")

这样读6万个数字,几乎就不需要时间了。

不知道金字塔的底层函数到底如何。但我想,如果HistoryData等对象,返回的直接是数组的话。整体的金字塔VBA代码,运行速度会飞一样的快。

建议:History = marketdata.GetHistoryData("rb00","sq",5)

是直接将("rb00","sq",5)它的所有数据,以数组的形式返回。

其它对象,涉及到数据的,同理。

这样就能真正发挥金字塔的VBA功能了。


 回到顶部