MQL4、MQL5に関する初心者からの質問、アルゴリズムやコードに関するヘルプ、ディスカッションなど。 - ページ 1719

 
Snajper007 売り注文が 出されたとき、この関数は平均価格を計算します。しかし、3番目の注文を開くと、この機能は前の値と新しい値を表示しますが(ジャーナルのプリントに目を通しました)、結果的に前の値のままになっています。私は何か悪いことをしたのだろうか?
//+----------------------------------------------------------------------------+
//| Расчет среденй цены (0)-buy (1)-sell                                       |
//+----------------------------------------------------------------------------+
double GetAveragePrice(int ot=-1)
  {
   double order_lots = 0, order_price = 0, avg_price = 0;
     {
      for(int i = OrdersTotal()-1; i>=0; i--)
        {
         if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
           {
            if(OrderSymbol() == Symbol() && OrderMagicNumber() == Magic)
              {
               if(OrderType()==ot||ot<0)
                 {
                  order_lots += OrderLots();
                  order_price += OrderOpenPrice() * OrderLots();
                 }
              }
           }
        }
     }
   avg_price = NormalizeDouble(order_price / order_lots, Digits);
   return(avg_price);
  }
//+----------------------------------------------------------------------------+
 
MakarFX #:
ありがとうございました。
 
こんにちは、誰が指標に基づいて取引を開くためのフィルタを実装するのに役立つことができますか?
 
Sergei Pimenov #:
こんにちは、誰が指標に基づいて取引開始フィルタを実装するのに役立つことができますか?
続きを読む
 

ロジックを練り直すのを手伝ってください。クローズしたオーダーと新しいオーダーを開く間に時間的な間が必要です。少しは解決した。しかし、うまくいかない。

OrderCloseTime() > 0 && TimeCurrent() - OrderCloseTime() > FstOrderTimeHour*3600 // сигнал на открытие ордера

OrderCloseTime() == 0 // сигнал на открытие первого ордера

где int FstOrderTimeHour = 1 // пауза в часах
 
Порт-моне тв #:

ロジックを練り直すのを手伝ってください。クローズしたオーダーと新しいオーダーを開く間に時間的な間が必要です。少しは解決した。しかし、うまくいかない。

//--- input parameters
input int HourPause = 1;   // Пауза в часах
//--- global parameters
datetime  pause;
//+------------------------------------------------------------------+
void OnTick()
  {
   pause=GetInfoLastPos(3)+(HourPause*60*60);
   // выключаем торговлю
   if(TimeCurrent()<pause) return;
  .......
  }
//+----------------------------------------------------------------------------+
//|  Функция возвращает по символу и магику                             MakarFX|
//|  1 - размер лота последней закрытой позиции                                |
//|  2 - размер профита с учетом комиссии и свопа последней закрытой позиции   |
//|  3 - время последней закрытой позиции                                      |
//+----------------------------------------------------------------------------+
double GetInfoLastPos(int a=1)
  {
   datetime t=0;
   double result=0,l=0,p=0,f=0;
   int i=OrdersHistoryTotal();
   for(int pos=0; pos<i; pos++)
     {
      if(OrderSelect(pos, SELECT_BY_POS, MODE_HISTORY))
        {
         if(OrderSymbol()==_Symbol && OrderMagicNumber()==Magic)
           {
            if(OrderType()==OP_BUY || OrderType()==OP_SELL)
              {
               if(t<OrderCloseTime()) {t=OrderCloseTime(); l=OrderLots(); p=OrderProfit()+OrderCommission()+OrderSwap();}
              }
           }
        }
     }
   if(a==1) {result=l;} else
   if(a==2) {result=p;} else
   if(a==3) {result=(double)t;}
   else     {result=0;}
   return(result);
  }
//+----------------------------------------------------------------------------+

マジシャンが不要な場合 - 黄色を削除する。

 
MakarFX #:

注文を開く前に、現在のmax_ticketをprev_ticketに格納します。

Good time Makarさん、このペナント順位のチケットの定義方法には、重大な欠点があります。この方法は、グリッド内の最大の注文が開かれる場合に機能し、そうならない場合は、ペネトレイト注文がグリッド内の最後の注文になります(図参照)。私は関数を書こうとしているが、それは最後のチケットが検出され、動作しません。 ハイライトされた条件は動作したくないです。

//+----------------------------------------------------------------------------+
//| Расчет тикета предпоследнего ордера в сетке                                 |
//+----------------------------------------------------------------------------+
int GetTicketPenultimateOrder()
  {
   penultimate_ticket = 0;
     {
      for(int cnt = OrdersTotal() - 1; cnt >= 0; cnt--)
        {
         if(OrderSelect(ticket, SELECT_BY_TICKET, MODE_TRADES))
           {
            if(OrderSymbol() == Symbol() && OrderMagicNumber() == Magic)
              {
               if(OrderType() == OP_BUY || OrderType() == OP_SELL)
                 {
                  if(OrderTicket() > penultimate_ticket)
                     if(penultimate_ticket < GetTicketMaxOrder())
                        penultimate_ticket = OrderTicket();

                 }
              }
           }
        }
     }
   return(penultimate_ticket);
  }

 
EVGENII SHELIPOV #:

グッドタイムマカー、このペナントオーダー券の方法には重大な欠点があります。この方法は、最大注文がグリッドで開かれている場合に有効です。 もし開かれていない場合、最後から2番目の注文は最後の注文と同じになります(図を参照)。私は関数を書こうとしているが、それは最後のチケットが検出され、動作しません。 ハイライトされた条件は動作したくないです。

動作するコードを お渡ししました
 
MakarFX #:
動作するコードを お渡ししました

このコードは、上に書いたもので、写真もあります

 
EVGENII SHELIPOV #:

このコードは、上に書いたもので、写真もあります

エラーは、ペナントの検索コードではなく、情報をテキストに出力する際に発生する可能性が高いです