Rss & SiteMap

金字塔客服中心 - 专业程序化交易软件提供商 http://www.weistock.com/bbs/

专业程序化软件提供商
共5 条记录, 每页显示 10 条, 页签: [1]
[浏览完整版]

标题:定时器整点运行

1楼
youop 发表于:2014/5/28 23:37:52
vba里的定时器Sub Application_Timer(Id),然后在

Call Application.Settimer(0,300000)

 

就是每隔5分钟执行一次,但是,我想让他整点运行,就是开盘以后9:05,9:10,9:15,在这样的整点每隔5分钟运行一次,这样运行,应该怎么操作呢?;

2楼
admin 发表于:2014/5/29 14:01:11
在定时器中判断当前计算机时间是不是到了你那个几个时间节点不就行了?
3楼
youop 发表于:2014/5/29 14:29:51
一天5分钟有45个节点。。。,用算法计算?
4楼
admin 发表于:2014/5/29 17:47:20

Sub APPLICATION_VBAStart()
    Call Application.Settimer(0,1000)
End Sub


Sub APPLICATION_Timer(ID)
   if Hour(now) >= 9 And Hour(now) <= 15 And Minute(Now) > 1 And Second(Now) < 1 Then
      DifMin = Minute(Now) Mod 5
      
      IF DifMin = 0 Then
         '这里执行你的操作
      End If
   End if
End Sub

 

这里的Settimer(0,1000)目的是1秒执行一次检测,目的是保证正好能在刚过执行点时能检测到,如果你的模型只需要间隔5分钟而不需要那么精确卡在时间点,将这里改成60秒即可,另外去掉And Second(Now) < 1这句即可

5楼
youop 发表于:2014/5/29 21:21:21
谢谢!没想到顺便把算法也给我了!实在太给力了!太谢谢了;
共5 条记录, 每页显示 10 条, 页签: [1]


Powered By Dvbbs Version 8.3.0
Processed in 0.29102 s, 2 queries.