初学者的问题 MQL5 MT5 MetaTrader 5 - 页 1113

 

问候。我看了 "从MQL4到MQL5--如何为Metatrader 5重写EA"的合格视频。
非常感谢作者。我已经决定自己尝试。我决定自己尝试一下。该想法如下。
1.我在输入中设置了dtriger = 1 - 买入打开。
2.我设置dtriger = -1 - 卖出开盘。
3.我设置dtriger = 0 - 所有打开的都关闭了。
我在MT5手册中看到,不可能持有相反的头寸。
而我拥有它们。
问题:如何正确规定未平仓头寸的平仓行为?
问题是:如何在开立反向头寸时正确登记现有头寸的关闭?
非常感谢。

#include <Trade\PositionInfo.mqh>
#include <Trade\Trade.mqh>
#include <Trade\SymbolInfo.mqh>
#include <Trade\OrderInfo.mqh>

CPositionInfo   o_position;
CTrade        o_trade;
CSymbolInfo        o_symbol;
COrderInfo         o_order;

input int          triger            = 0;
input double    StartLot             = 0.01;
input double    lpos_volume       = 1.0;
input int          Step         = 10;
input int          MagicNumber    = 12345;      //      Magic   nuaber
input int          Slippage          = 30;         //   slippage

int dtriger;
int dStep;

//+------------------------------------------------------------------+
//| Expert initialization function                                   |
//+------------------------------------------------------------------+
int OnInit()
  {
   dStep = Step ;
   dtriger = triger ;

   if (!o_symbol.Name(Symbol()))
     return(INIT_FAILED);
   
   RefreshRates();
   
   o_trade.SetExpertMagicNumber(MagicNumber) ;

   if (IsFillingTypeAllowed(o_symbol.Name(), SYMBOL_FILLING_FOK))
   { 
      o_trade.SetTypeFilling(ORDER_FILLING_FOK);
   }
   else if (IsFillingTypeAllowed(o_symbol.Name(), SYMBOL_FILLING_IOC))
   { 
      o_trade.SetTypeFilling(ORDER_FILLING_IOC);
   }
   else 
   {
      o_trade.SetTypeFilling(ORDER_FILLING_RETURN);
   }
      o_trade.SetDeviationInPoints(Slippage);
   
   if (o_symbol.Digits() == 3 || o_symbol.Digits() == 5 )
   {
      dStep = 10 ;
   }
   
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Expert deinitialization function                                 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
  {
  }
//+------------------------------------------------------------------+
//| Expert tick function                                             |
//+------------------------------------------------------------------+
void OnTick()
  {
      datetime              lpos_time          =        0;
      double                lpos_price_open    =        0.0;
      ENUM_POSITION_TYPE   lpos_type           =        -1;
      int                      pos_count               =        0;
      double                sum_profit         = 0;
 
   for (int i = PositionsTotal() - 1; i>=0; i--)
   {
      if (o_position.SelectByIndex(i))
      {
         if (o_position.Symbol() == o_symbol.Name() && o_position.Magic() == MagicNumber)
         {
            if (o_position.Time() > lpos_time)
            {  
               lpos_time       = o_position.Time();            //OrderOpenTime();
               lpos_price_open = o_position.PriceOpen();       //OrderOpenPrice();
               lpos_type       = o_position.PositionType() ;   //OrderTipe();
             }  
            
            pos_count++;
            sum_profit = sum_profit + o_position.Commission() + o_position.Swap() + o_position.Profit() ;
          }     
       }     
    }          

   // Считаем кол-во отложенных ордеров
  int stop_count=0;

   for (int i=OrdersTotal()-1; i >=0; i--) 
   {
      if (o_order.SelectByIndex(i)) 
      {
         if (o_order.Symbol() == o_symbol.Name() && o_order.Magic() == MagicNumber) 
           stop_count++;
      }
   }

   if (!RefreshRates())
     return ;
     
   if(dtriger == 0 )
   {
      CloseAll();
      return;               
   } 
   
  // + -----    Откраваем Первый ордер   ++++++++++
 if (pos_count == 0  && stop_count == 0    )
   {
      if ( dtriger == -1 &&  lpos_type != POSITION_TYPE_SELL)
      {
         o_trade.Sell(StartLot * lpos_volume , o_symbol.Name());  //   S E L L   11111
      }
      
      if ( dtriger == 1 &&  lpos_type != POSITION_TYPE_BUY )
      {
         o_trade.Buy(StartLot * lpos_volume , o_symbol.Name());   //   B U Y    11111
      }
   }
                          

// +  -----   Переворот    ++++++++++++++++++++++++++++   

if (pos_count>0)
   {
      if(lpos_type == POSITION_TYPE_BUY )
      {
         if ( dtriger == -1 )
         {
         o_trade.Sell(StartLot * lpos_volume , o_symbol.Name());   //   S E L L   +++++
         }
      }

      if (lpos_type==POSITION_TYPE_SELL )
      {
         if ( dtriger == 1 )
         {
         o_trade.Buy(StartLot * lpos_volume , o_symbol.Name());       //   B U Y    +++++
         }
      }
   }


   if(pos_count>0 && stop_count>0) 
     DeleteStopOrders() ;
  
} 
//-----------------------------------------------------------
bool RefreshRates()
{
   if (!o_symbol.RefreshRates())
     return(false) ;
     
    if (o_symbol.Ask() == 0 || o_symbol.Bid() == 0)
      return(false);
      
    return(true);
}  
//---  --------------------------------------------------------- 
 bool IsFillingTypeAllowed (string symbol, int fill_type)
{ 
   int filling = (int)SymbolInfoInteger(symbol, SYMBOL_FILLING_MODE); 
 
   return((filling && fill_type) == fill_type) ;
} 
 
 //  -------------------------------------------------- 
   void CloseAll()
{
   for (int index = PositionsTotal()-1; index >=0; index--)
   {
      if (o_position.SelectByIndex(index))
      {
         if (o_position.Symbol() == o_symbol.Name() && o_position.Magic() == MagicNumber)
         {
            o_trade.PositionClose(o_position.Ticket());
         }
      }  
    } 
 } 
  
 //----------------------------------------------------------- 
 // Delete all pending orders
 //-------------------------------------
 void DeleteStopOrders()
 {
    for (int i = OrdersTotal() - 1; i >= 0; i-- ) 
   {
      if (o_order.SelectByIndex(i))
         if(o_order.Symbol() == o_symbol.Name() && o_order.Magic() == MagicNumber)
            o_trade.OrderDelete(o_order.Ticket());
   }
 } 
 
//+------------------------------------------------------------------+
 
procom:

问候。我看了 "从MQL4到MQL5--如何为Metatrader 5重写EA"的有用片段。
我想向作者表示祝贺。我已经决定自己尝试。我写的。我的想法是这样的。
1.我设置dtriger = 1 - 打开购买。
2.我设置dtriger = -1 - 卖出开盘。
3.我设置dtriger = 0 - 所有打开的都关闭了。
我在常见问题中看到,在MT5中不可能持有相反的头寸。
而我拥有它们。
问题:如何正确规定未平仓头寸的平仓行为?
问题是:如何在开立反向头寸时正确登记现有头寸的关闭?
非常感谢。

你在阅读概况介绍时一定很不专心。

参考:一般原则--交易业务

一句话:MetaTrader 5同时拥有净值交易 对冲系统

Общие принципы - Торговые операции - MetaTrader 5
Общие принципы - Торговые операции - MetaTrader 5
  • www.metatrader5.com
Перед тем как приступить к изучению торговых функций платформы, необходимо создать четкое представление об основных терминах: ордер, сделка и позиция. — это распоряжение брокерской компании купить или продать финансовый инструмент. Различают два основных типа ордеров: рыночный и отложенный. Помимо них существуют специальные ордера Тейк Профит...
 

我将以不同的方式制定你的任务。

1. dtriger = 1 - 买入开盘。
2. dtriger = -1 - 卖出开盘。
3. dtriger = 0 - 所有开盘的都关闭。

专家顾问应做到以下几点。

  • 如果你需要打开买入 - 你应该先关闭卖出(发出关闭卖出头寸的命令 - 无论它们是否存在都无所谓)。
  • 如果你需要打开SELL - 那么首先你需要关闭BUY(关闭BUY头寸的命令将被发出,它们是否存在并不重要)。
  • 如果客户需要关闭所有 - 那么就关闭所有头寸(无论他们是买入还是卖出)。

实施时需要两种算法(神奇的数字在这里也有贡献)--它可以被禁用。

//+------------------------------------------------------------------+
//| Close positions                                                  |
//+------------------------------------------------------------------+
void ClosePositions(const ENUM_POSITION_TYPE pos_type)
  {
   for(int i=PositionsTotal()-1;i>=0;i--) // returns the number of current positions
      if(m_position.SelectByIndex(i))     // selects the position by index for further access to its properties
         if(m_position.Symbol()==m_symbol.Name() && m_position.Magic()==InpMagic)
            if(m_position.PositionType()==pos_type) // gets the position type
               m_trade.PositionClose(m_position.Ticket()); // close a position by the specified symbol
  }

и

//+------------------------------------------------------------------+
//| Close all positions                                              |
//+------------------------------------------------------------------+
void CloseAllPositions(void)
  {
   for(int i=PositionsTotal()-1;i>=0;i--) // returns the number of current positions
      if(m_position.SelectByIndex(i))     // selects the position by index for further access to its properties
         if(m_position.Symbol()==m_symbol.Name() && m_position.Magic()==InpMagic)
            m_trade.PositionClose(m_position.Ticket()); // close a position by the specified symbol
  }


一般的想法是围绕所有的位置从PositionsTotal()-1到0进行循环。是从PositionsTotal()-1到0,而不是从0到PositionsTotal()-1。这很重要。

 
还有一点建议:在MetaTrader 5中工作时,订单是一个REMOVED ORDER。因此,强烈建议你在这个初始阶段甚至不要提出 "订单 "这个词,以免在你的头脑中造成混乱。
 
Vladimir Karputov:
还有一点建议:在MetaTrader 5中工作时,订单是一个REMOVED ORDER。因此,强烈建议你在这个初始阶段甚至不要提出 "订单 "这个词,以免在你的头脑中造成混乱。

也有市场订单买入和卖出,以及CloseBy订单。

 

非常感谢你,就像音乐一样。

 
procom:

非常感谢你,就像音乐一样。

如果你需要对我的代码进行解释,请问。
 

好吧,如果你愿意的话,那就多多益善。
我已经输入了条目,并规定了预关闭,但订单又是挂在那里,不知道在哪里。

// +  -----   Переворот    ++++++++++++++++++++++++++++   

if (pos_count>0)
   {
      if(lpos_type == POSITION_TYPE_BUY )
      {
         if ( dtriger == -1 )
         {
         o_trade.PositionClose(o_symbol.Name());
         }
         {
         o_trade.Sell(StartLot * lpos_volume , o_symbol.Name());   //   S E L L   +++++
         }
      }

      if (lpos_type==POSITION_TYPE_SELL )
      {
         if ( dtriger == 1 )
         {
         o_trade.PositionClose(o_symbol.Name());
         }
         {
         o_trade.Buy(StartLot * lpos_volume , o_symbol.Name());       //   B U Y    +++++
         }
      }
   }
 
procom:

好吧,如果你愿意的话,那就多多益善。
我已经插入了条目并规定了预收盘,但这里和那里都有挂单。

关闭和打开的操作需要分开,也就是说,不要在一个堆中执行这些操作。
一个示例计划:OnTick()首先检查三个标志:ExtNeedCloseBuy、ExtNeedCloseSell和ExtNeedCloseAll。
然后我们才检查两个标志:ExtNeedOpenBuy和ExtNeedOpenSell。
这样一来,一切都将严格按照顺序运行。
而且,是的,没有订单:有的是开放的位置
 
procom:

非常感谢你,就像笔记一样。

打开的信号是什么?因为代码并不完整--只有平仓,但我还需要开仓......。


交易指令.mq5
#财产版本 "1.000"

到目前为止,它只执行了三个动作。

  • 关闭所有采购
  • 关闭所有卖家
  • 关闭所有买入和卖出
获利、止损和追踪都已内建。唯一缺少的是对开仓信号的描述。
Совершение сделок - Торговые операции - MetaTrader 5
Совершение сделок - Торговые операции - MetaTrader 5
  • www.metatrader5.com
Торговая деятельность в платформе связана с формированием и отсылкой рыночных и отложенных ордеров для исполнения брокером, а также с управлением текущими позициями путем их модификации или закрытия. Платформа позволяет удобно просматривать торговую историю на счете, настраивать оповещения о событиях на рынке и многое другое. Открытие позиций...
附加的文件: