有您的持续关注
我们会做得更好

MQL4编程:MQL4交易处理函数(一)



MQL4交易处理函数(一)

从自定义指标中不能调用OrderSend()、OrderClose()、OrderCloseBy()、OrderDelete()和OrderModify()交易函数。

本组交易函数应用于智能交易和脚本中。只有智能交易设置中的“允许实时交易”属性被选中,才能调用交易函数。

为了在智能交易和脚本中进行交易,在程序交易环境(智能交易和脚本的自动交易的环境)中,只能为它提供一个线程。这就是为什么,如果这个交易环境被 一个智能交易操作占用,因此会出现146错误(ERR_TRADE_CONTEXT_BUSY),其他智能交易或脚本在此时就不能调用成功。为了能确定是 否有交易在进行,可使用 IsTradeAllowed() 函数检测。为了清除交易环境下访问共享,我们能够使用个基于全局变量的交易信号,其值可以使用 GlobalVariableSetOnCondition() 函数改变。

  • OrderSelect() – 选择订单
  • OrderClose() – 平仓
  • OrderCloseBy() – 相反头寸平仓
  • OrderClosePrice() – 获取订单平仓价格
  • OrderCloseTime() – 获取订单平仓时间
  • OrderComment() – 获取订单注释
  • OrderCommission() – 获取订单佣金数额
  • OrderDelete() – 删除挂单
  • OrderExpiration() – 获取挂单有效时间
  • OrderLots() – 获取订单交易手数
  • OrderMagicNumber() – 获取订单魔术编号
  • OrderModify() – 修改订单
  • OrderOpenPrice() – 获取订单开仓价格
  • OrderOpenTime() – 获取订单开仓时间
  • OrderPrint() – 打印订单信息
  • OrderProfit() – 获取订单盈利金额
  • OrderSend() – 发出订单
  • OrdersHistoryTotal() – 获取历史订单总数
  • OrderStopLoss() – 获取订单止损值
  • OrdersTotal() – 获取订单总数
  • OrderSwap() – 获取订单掉期值
  • OrderSymbol() – 获取订单交易品种
  • OrderTakeProfit() – 获取订单止盈值
  • OrderTicket() – 获取订单的订单编号
  • OrderType() – 获取订单交易类型

 

OrderSelect() – 选择订单

bool OrderSelect(int index, int select, void pool)

本函数选择一个订单,等待做进一步地处理。如果函数成功,返回TRUE,如果函数失败,返回FALSE。想要获得详细错误信息,请调用GetLastError()函数。

如果通过订单编号选定定单,pool参数应忽略。此订单编号是其唯一识别符。找出所选订单的列表,对订单时间进行分析。如果订单时间为零,此订单就 是开单或挂单,或从终端开仓部位列表中选出。我们可以从订单类型区别开单和挂单。如果订单的平仓时间不等于0,此订单就是一个已经平仓的订单,或是一个已 删除的挂单,也可能是从终端历史中被选出来的,他们同样可以根据定单类型相互区别。

参数:

index  - 定单索引或订单号,这取决于第2个参数 
select - 选定模式。可以为以下的任意值:
         SELECT_BY_POS - 按订单表中索引 
          SELECT_BY_TICKET - 按订单号 
pool   - 可选择定单索引。当选择SELECT_BY_POS参数时使用。可以为以下的任意值:
         MODE_TRADES (默认)- 来自交易的定单(开单和挂单),
          MODE_HISTORY - 来自历史的定单(已平仓或取消的订单)。

示例:

  if(OrderSelect(12470, SELECT_BY_TICKET)==true)
    {
     Print("定单 #12470 开价格", OrderOpenPrice());
     Print("定单 #12470 收盘价格 ", OrderClosePrice());
    }
  else
    Print("OrderSelect 返回的错误 ",GetLastError());

OrderClose() – 平仓

bool OrderClose(int ticket, double lots, 
                double price, int slippage, void Color)

定单平仓。如果函数执行成功,返回TRUE。如果函数执行失败,返回FALSE。想要获得详细错误信息,请调用GetLastError()函数。

参数:

ticket   - 订单号。 
lots     - 平仓手数。 
price    - 平仓价格。 
slippage - 最高滑点数。 
Color    - 图表中平仓箭头颜色。如果参数丢失或用CLR_NONE值,将不会在图表中画出。

示例:

  if(iRSI(NULL,0,14,PRICE_CLOSE,0)>75)
    {
     OrderClose(order_id,1,Ask,3,Red);
     return(0);
    }

OrderCloseBy() – 相反头寸平仓

bool OrderCloseBy(int ticket, int opposite, void Color)

用相反定单对打开仓位进行平仓操作。如果函数成功,返回TRUE。如果函数失败,返回FALSE。获得详细错误信息,请查看GetLastError()函数。

参数:

ticket   - 订单号。 
opposite - 相反订单的订单号。 
Color    - 图表中平仓箭头颜色。如果参数丢失或用CLR_NONE值,将不会在图表中画出。

示例:

  if(iRSI(NULL,0,14,PRICE_CLOSE,0)>75)
    {
     OrderCloseBy(order_id,opposite_id);
     return(0);
    }

OrderClosePrice() – 获取订单平仓价格

double OrderClosePrice()

获取订单平仓价格。对于已经平仓的订单返回平仓时价格,对于未平仓订单返回该订单货币对的实时价格。

注:定单必须用 OrderSelect() 函数提前选定。

示例:

  if(OrderSelect(ticket,SELECT_BY_POS)==true)
    Print("对于订单的收盘价格",OrderClosePrice());
  else
    Print("OrderSelect 失败错误代码是",GetLastError());

OrderCloseTime() – 获取订单平仓时间

datetime OrderCloseTime()

返回当前订单的平仓时间。如果定单的平仓时间不是0,所选订单会从账户历史重新尝试。未平仓的订单和挂单交易的平仓时间等于0。

注:定单必须用 OrderSelect() 函数提前选定。

示例:

  if(OrderSelect(10,SELECT_BY_POS,MODE_HISTORY)==true)
    {
     datetime ctm=OrderOpenTime();
     if(ctm>0) Print("定单10 开仓时间", ctm);
     ctm=OrderCloseTime();
     if(ctm>0) Print("定单 10 平仓时间", ctm);
    }
  else
    Print("OrderSelect失败错误代码是",GetLastError());

OrderComment() – 获取订单注释

string OrderComment()

返回当前订单的注释。

注:定单必须用 OrderSelect() 函数提前选定。

示例:

  string comment;
  if(OrderSelect(10,SELECT_BY_TICKET)==false)
    { Print("OrderSelect 失败错误代码是",GetLastError());
     return(0);
    }
  comment = OrderComment();
  // ...

OrderCommission() – 获取订单佣金数额

double OrderCommission()

返回当前订单的佣金数额。

注:定单必须用 OrderSelect() 函数提前选定。

示例:

  if(OrderSelect(10,SELECT_BY_POS)==true)
    Print("定单10 "佣金,OrderCommission());
  else
   Print("OrderSelect 失败错误代码是",GetLastError());

OrderDelete() – 删除挂单

bool OrderDelete(int ticket, void Color)

删除指定订单的挂单。如果函数成功,返回TRUE。如果函数失败,返回FALSE。获得详细错误信息,请查看GetLastError()函数。

参数:

ticket   - 要删除的订单(挂单)号。  
Color    - 图表中平仓箭头颜色。如果参数丢失或用CLR_NONE值,将不会在图表中画出。

示例:

  if(Ask>var1)
    {
     OrderDelete(order_ticket);
     return(0);
    }

OrderExpiration() – 获取挂单有效时间

datetime OrderExpiration()

返回当前挂单的有效时间。

注:定单必须用 OrderSelect() 函数提前选定。

示例:

  if(OrderSelect(10, SELECT_BY_TICKET)==true)
    Print("定单 #10 有效日期为",OrderExpiration());
  else
    Print("OrderSelect 返回的",GetLastError()错误);

OrderLots() – 获取订单交易手数

double OrderLots()

返回当前订单的交易手数。

注:定单必须用 OrderSelect() 函数提前选定。

示例:

  if(OrderSelect(10,SELECT_BY_POS)==true)
    Print("定单 10 交易手数",OrderLots());
  else
    Print("OrderSelect 返回的 ",GetLastError()错误);

OrderMagicNumber() – 获取订单魔术编号

int OrderMagicNumber()

返回当前订单的魔术编号。

注:定单必须用 OrderSelect() 函数提前选定。

示例:

  if(OrderSelect(10,SELECT_BY_POS)==true)
    Print("定单 10 的魔术编号", OrderMagicNumber());
  else
    Print("OrderSelect 返回的 ",GetLastError()错误);

OrderModify() – 修改订单

bool OrderModify(int ticket, double price, double stoploss, 
                 double takeprofit, datetime expiration, 
                 void arrow_color)

修改以前的开仓或挂单的订单参数。如果函数成功,返回TRUE。如果函数失败,返回FALSE。如果想获取详细的错误信息,请调用GetLastError()函数。

注:只有挂单才能修改开仓价和过期时间。

如果用原值作为参数传递给该函数,将会产生错误代码为1的信息 (ERR_NO_RESULT)。

在某些交易服务器上,挂单的过期时间被禁用。这种情况下,当在过期参数中指定一个非零值时,将生成147错误(ERR_TRADE_EXPIRATION_DENIED)。

参数:

ticket     - 要修改的订单(挂单)号。
price      -  新的开仓价格。(对于挂单有效) 
stoploss   -   新止损价位。 
takeprofit -   新止盈价位。 
expiration -   挂单有效时间。(对于挂单有效)  
Color      - 图表中平仓箭头颜色。如果参数丢失或用CLR_NONE值,将不会在图表中画出。

示例:

  if(TrailingStop>0)
    {
     OrderSelect(12345,SELECT_BY_TICKET);
     if(Bid-OrderOpenPrice()>Point*TrailingStop)
       {
        if(OrderStopLoss()<Bid-Point*TrailingStop)
          {
           OrderModify(OrderTicket(),OrderOpenPrice(),Bid-Point*TrailingStop,OrderTakeProfit()
,0,Blue);
           return(0);
          }
       }
    }

如您喜欢此文章请点下面分享按钮↴峰汇在线 » MQL4编程:MQL4交易处理函数(一)
上一篇:
下一篇:
分享到:更多 ()