我正在尝试修改订单,但我总是 Error #1
。
从我的研究中,我发现错误1意味着我输入参数的方式错误。如何修复 OrderModify()
功能?
stoploss = NormalizeDouble(Ask - Point * TrailingStop,Digits);
int ticket;
takeprofit = NormalizeDouble(Ask + Point * TrailingStopTP,Digits);
double minstoplevel = MarketInfo( Symbol(), MODE_STOPLEVEL );
if(stoploss > NormalizeDouble(Ask - Point*minstoplevel,Digits)) {
stoploss = NormalizeDouble(Ask - Point*minstoplevel,Digits);
}
if(takeprofit < NormalizeDouble( Ask + Point*minstoplevel2, Digits )) {
takeprofit = NormalizeDouble( Ask + Point*minstoplevel2, Digits );
}
if(AccountFreeMarginCheck(Symbol(),OP_SELL,lotsize)>0) {
ticket=OrderSend(Symbol(),OP_BUY,lotsize,Ask, 0, 0.0, 0.0, "comment", MagicNumber, 0, Lime);
if(ticket<0) {
Print("Order send failed with error #",GetLastError());
} else {
Print("Order send sucesso!! Ticket#", ticket);
res=OrderModify(ticket,OrderOpenPrice(),stoploss,takeprofit,0,Blue);
if(res==false) {
Print("Error modifying order!, error#",GetLastError());
} else {
Print("Order modified successfully, res#", res);
}
}
} else {
Print("Sem dinheiro na conta D=");
}
}
答案 0 :(得分:2)
OrderModify()
合法设置_LastError == 1
可能会有点意外,但 OrderModify()
有义务发出 _LastError == 1
信号,以防通话,无论是语法上还是语义上但是,正确的是,为修改提供的值实际上是相同的,因为已识别的 ticket#
已经存在于数据库中。
这意味着,没有任何内容可以修改,因为所有属性都已经具有“ quasi- new ”目标值。
可以预先检查所有字段的潜在身份,这可能允许我们的代码在这种情况下跳过OrderModify()
调用{当前|目标}值。
ERR_NO_RESULT == 1 // No error returned, but the result is unknown
GetLastError()
- 返回上次生成的错误代码。通过名为 _LastError
的系统变量可以获得相同的值。通过调用 ResetLastError()
,可以在关键活动为零之前重置该值。
错误代码在 stderror.mqh
中定义。
要打印错误说明,您可以使用 ErrorDescription()
文件
stdlib.mqh
功能
#include <stderror.mqh>
#include <stdlib.mqh>
答案 1 :(得分:1)
问题在于,即使 OrderModify()
来电的入场价,止损和止盈参数看起来相同,它们也可能相差一小部分(小于“数字”)。
要解决此问题,请简单地对参数进行规范化,以确保它们的长度最多为 Digits
小数。
double entryPrice = NormalizeDouble( entryPrice, Digits );
double stoploss = NormalizeDouble( stoploss, Digits );
double target = NormalizeDouble( target, Digits );
然后将其传递给OrderModify()
来电。