以文本方式查看主题 - 金字塔客服中心 - 专业程序化交易软件提供商 (http://weistock.com/bbs/index.asp) -- 交易策略发布专区 (http://weistock.com/bbs/list.asp?boardid=10) ---- DEBUGFILE和DEBUGFILE2的写法 (http://weistock.com/bbs/dispbbs.asp?boardid=10&id=66051) |
-- 作者:无极无名 -- 发布时间:2014/6/11 15:11:35 -- DEBUGFILE和DEBUGFILE2的写法 这两个函数的用户体验太那个什么了。现做一个详细的说明,为新手节约点时间(我就是这么好心) 一、debugfile只在最后一个周期才执行,debugfile2可作用于所有周期。这个大概谁都能明白。 二、两者都可以往指定文件输出特定的唯一的数字,但是
DEBUGFILE(PATH,STR,NUM),没有参数N,写了参数则公式通不过。始终输出打印时间。
DEBUGFILE2(PATH,STR,NUM,N),有参数N,小心了!N<=0不打印输出时间,N>0(不见得是整数)输出打印时间。不写参数N则公式通不过。 三、DEBUGFILE(\'D:\\TEST.TXT\',\'当前资产为%.2f\',1234)
DEBUGFILE2(\'D:\\TEST.TXT\',\'当前资产为%.2f\',1234,1)
‘%.2f’这个打印控制符里面的‘f’必须小写,否则公式能通过,但是数字输出为空。这算是小意思了,不算为难你。 四、DEBUGFILE除了可以输出指定数字以外,还可以输出一连串的字符串,包括把数字转化为字符串,没有控制符‘%.2f’了,例:
debugfile(
\'D:\\TEST.TXT\' ,\'当前价格: \'+numtostr(close,2)
+\' \'+\'开盘价 \'+numtostr(open,2),-1);
但是,你发现这个例子里面最后有个参数‘-1’,是什么?这是为难你的地方。DEBUGFILE本身没有输出时间控制参数N(见第二条),
所以这最后面的数字不是参数N,不是控制是否输出打印时间的。但是必须要有个数,随便是什么数,但是不能空。
空则公式通不过。
DEBUGFILE2除了可以输出指定数字以外,还可以输出一连串的字符串,包括把数字转化为字符串,没有控制符‘%.2f’了,例:
debugfile2( \'D:\\TEST.TXT\' ,\'当前价格: \'+numtostr(close,2) +\' \'+\'开盘价 \'+numtostr(open,2),-1,10);
请注意最后两个参数-1和10,因为DEBUGFILE2带有参数N(见第二条),所以该例句中最后一个数10是参数N,10>0因此要打印输出时间。
而前面那个-1,则代表填任意数字都行。后面两个数都必须填,少一个,则公式通不过。 五、总算是搞明白了。看下面的
debugfile2( \'D:\\TEST.TXT\' ,\'当前价格: \'+numtostr(close,2) +\' \'+\'开盘价 \'+numtostr(open,2),-1,10);
的输出结果:
2014-06-11 14:42:30.630 当前价格: 2154.00 开盘价2155
有什么不对吗?有。当前价格‘2154.00’带有小数,开盘价‘2155’没小数(不是也应该带小数吗?)哎,输不了那么多字符串,
debugfile2对输出字符串数量有限制,中文字符串一个顶几个,到后面输不出来小数了。 |
-- 作者:jinzhe -- 发布时间:2014/6/11 15:31:26 -- 给力了 |
-- 作者:无极无名 -- 发布时间:2014/6/11 23:54:08 -- 呵呵,有10个金币奖励。这个函数用“%.0f”这样的打印控制符,来输出监控数字,费解且容易出错, 函数的说明远远没有使用的那般方便和强大。 建议废除这样的写法,或者至少在函数说明里面做更清晰的补充说明。加上: 用户也可以直接将需要监控的数字变量的数值转化为字符串,并且可以将多个字符串相加输出。 用法:DEBUGFILE2(PATH,STR,\'\',N),PATH为用户本地计算机计算机路径,STR为用户需要监控打印的字符串,\'\'为一个空字符串(该字符串不会输出,但是该参数不可省略), N为一个数字变量(用户可直接填数字或者填变量名)用以控制是否自动输出打印时间,N<=0不输出时间,N>0输出时间。例: debugfile2( \'D:\\TEST.TXT\' ,\'当前价格: \'+numtostr(close,2) ,‘’,1);
[此贴子已经被作者于2014/6/11 23:55:09编辑过]
|