初心者の方からの質問 MQL5 MT5 MetaTrader 5 - ページ 120

 

            int digits = (int)SymbolInfoInteger(_Symbol,SYMBOL_DIGITS);       // number of decimal places
            double point = SymbolInfoDouble(_Symbol,SYMBOL_POINT);            // point
            double ask = SymbolInfoDouble(_Symbol,SYMBOL_ASK);                // current price for closing SHORT
            double SL = ask-_SL*point;                                        // unnormalized SL value
            SL = NormalizeDouble(SL,digits);                                  // normalizing Stop Loss
            double   TP = ask+_TP*point;                                      // unnormalized TP value
            TP = NormalizeDouble(TP,digits);                                  // normalizing Take Profit
            double   open_price = SymbolInfoDouble(_Symbol,SYMBOL_BID);

            if(!trade.Buy(Volume,_Symbol,open_price,SL,TP,""))
               {
                  //--- failure message
                  Print("Sell() method failed. Return code=",trade.ResultRetcode(),
                  ". Code description: ",trade.ResultRetcodeDescription());
                  return (false);             
               }
            else
               {
                  Print("Sell() method executed successfully. Return code=",trade.ResultRetcode(),
                  " (",trade.ResultRetcodeDescription(),")");
               }

ストラテジーテスターで ストップロスやプロフィットを設定せず、マーケットプライスでポジションを持つのはなぜですか?

CTrade(trade.Buy)を使って、ポジションを開設しています。

(trade.PositionOpen)で開いてみましたが、同じように、デモで開いてストップをかけています。

 
プログラマーの皆さん、こんにちは。プログラマーは神様のような存在だと思います。無から有を生み出し、物質的なものを作り出すことは、まさに素晴らしいことです。時間に関する記事を読みましたが、周期性の設定については何も書かれていません。周期性どころか、ある時間帯にあるExpert Advisorを有効にしたり無効にしたりすることさえも書かれていないのです。そんな質問をされたことはないだろう。EAの名前を変えてスタートとストップのタイミングを変えているのですが、MT5には1ペア-1EAしかないので、手動で切り替えています。感謝
 
Top2n:

手動でできるのはわかるが、ロボットにやってもらいたい。

注文を修正する関数を作成するにはどうすればよいですか?

https://www.mql5.com/ru/articles/134
Как создать свой Trailing Stop
Как создать свой Trailing Stop
  • 2010.08.05
  • Dmitry Fedoseev
  • www.mql5.com
Основное правило трейдера - дай прибыли расти, обрезай убытки! В статье рассматривается один из основных технических приемов, позволяющий следовать этому правилу - перемещение уровня защитной остановки (уровня Stoploss) вслед за растущей прибылью позиции, другими словами - скользящий стоп или трейлинг стоп (trailingstop). Приводится пошаговая процедура создания класса для трейлинг стопа на индикаторах SAR и NRTR, который каждый желающий сможет за 5 минут встроить в своего эксперта или использовать независимо для управления позициями на своем счете.
 
トレーリングバーを設定したが、適切なタイミングでON/OFFされず、反転を考慮しない。アイデアはこれです:トレーリングストップ後、通常は期間の終了時に、例えば1時間または15分、数分待って、それが再びオンにし、インジケータによってレイアウトを決定し、次のストップに移動してみましょう...:-)))です。)
 
EAの最低入金額1000&(ドル口座)か1000ルーブル(ルーブル口座)の違いがあれば教えてください。
 
Pavel777:
こんにちは、EAのための違いがあるかどうか教えてください:1000&(ドル口座)または1000ルーブル(ルーブル口座)の最低入金額?
エキスパートアドバイザーだけでなく、全てに依存します。メインはEAのロットサイズだと思うのですが。
 

親愛なる皆様、助けてください!!!すでに最後のステップで落胆している、出来合いの戦略から。トレードの平均化ができない、スルー

 bool PositionModify(const string smb,const double SL,const double TP)
  {       
      MqlTradeRequest mrequest={0};
      MqlTradeResult  mresult ={0};
      
      mrequest.action   = TRADE_ACTION_SLTP;
      mrequest.symbol = _Symbol;   
      mrequest.sl       = SL;
      mrequest.tp       = TP;
      
      OrderSend( mrequest, mresult );
      if( mresult.retcode == 10009 || mresult.retcode == 10008 )//запрос выполнен или ордер успешно помещен
      {          
         Alert( "Стопка прошла#:", mresult.order, "!!" );
      }
      else
      {
         Alert( "Стопка не прошла - код ошибки:", GetLastError() );
         return( false );
      }   
   return( true );
  }

トレードを平均化しようとするしかし、パラメータでは

PositionModify(Symbol,SL,ТР)

始値を取得し、平均化した結果ずれた値を知りたいので、始値を決定できない。

またはちょうど注文履歴を介して 最初と2番目の注文の価格を見つけるために、すでにこれらのデータに基づいて平均化されるように、私はそれが私のためにあまりにも複雑であるこの方法を望んでいない

 datetime end=TimeCurrent();                 // текущее серверное время
   datetime start=end-PeriodSeconds(PERIOD_D1);// установим начало на сутки назад
//--- запросим в кэш программы нужный интервал торговой истории
   HistorySelect(start,end);
//--- получим количество сделок в истории
   int deals=HistoryDealsTotal();
//--- получим тикет сделки, имеющей последний индекс в списке
   ulong deal_ticket=HistoryDealGetTicket(deals-1);
   if(deal_ticket>0) // получили в кэш сделку, работаем с ней
     {
      //--- тикет ордера, на основании которого была проведена сделка
      ulong order     =HistoryDealGetInteger(deal_ticket,DEAL_ORDER);
      long order_magic=HistoryDealGetInteger(deal_ticket,DEAL_MAGIC);
      long pos_ID     =HistoryDealGetInteger(deal_ticket,DEAL_POSITION_ID);
    

double priceh   =HistoryDealGetInteger(deal_ticket,DEAL_PRICE);  // не могу определить цену открытия

      PrintFormat("Сделка #%d по ордеру #%d с ORDER_MAGIC=%d участвовала в позиции %d",                   deals-1,order,order_magic,pos_ID);      }    else              // неудачная попытка получения сделки      {       PrintFormat("Всего в истории %d сделок, не удалось выбрать сделку"+                   " с индексом %d. Ошибка %d",deals,deals-1,GetLastError());      }      //--- получим общее количество позиций    int positions=PositionsTotal(); //--- пробежим по списку ордеров    for(int i=0;i<positions;i++)      {       ResetLastError();       //--- скопируем в кэш позицию по ее номеру в списке       string symbol=PositionGetSymbol(i); //  попутно получим имя символа, по которому открыта позиция       if(symbol!="") // позицию скопировали в кэш, работаем с ней         {          long pos_id            =PositionGetInteger(POSITION_IDENTIFIER);          double price           =PositionGetDouble(POSITION_PRICE_OPEN);          ENUM_POSITION_TYPE type=(ENUM_POSITION_TYPE)PositionGetInteger(POSITION_TYPE);          long pos_magic         =PositionGetInteger(POSITION_MAGIC);          string comment         =PositionGetString(POSITION_COMMENT);          if(pos_magic==EA_Magic)            {          

 PositionModify(Symbol(),NormalizeDouble(( - StopLoss*_Point),4),                                 NormalizeDouble(( + TakeProfit*_Point),4)); //  ну здесь еще через запрос в зависимости от типа ордера

           }          PrintFormat("Позиция #%d по %s: POSITION_MAGIC=%d, цена=%G, тип=%s, комментарий=%s",                      pos_id,symbol,pos_magic,price,EnumToString(type),comment);         }       else           // вызов PositionGetSymbol() завершился неудачно         {          PrintFormat("Ошибка при получении в кэш позиции c индексом %d."+                      " Код ошибки: %d", i, GetLastError());         }      }


 
Top2n:

親愛なる皆様、助けてください!!!すでに最後のステップで落胆している、出来合いの戦略から。トレードの平均化ができない、スルー

平均的な取引をしたいんだしかし、パラメータでは

始値を取得し、平均化した結果ずれた値を知りたいので、始値を決定できない。

またはちょうど注文履歴を介して 最初と2番目の注文の価格を見つけるために、すでにこれらのデータに基づいて平均化されるように、私はそれが私のためにあまりにも複雑であるこの方法を望んでいない

まず、手動で平均化アルゴリズムを描くべきでしょう。これでストップロスの値がマイナスになり、実際のストップロス価格が表示されるはずです。これらのパラメータは、使用する平均化アルゴリズムに応じて設定する必要があります。
 
以前はextern型だった変数がinputになったが、すでに定数になっている、externは現在インジケータメニューに表示されていない。今まで通りできるのか、それともこれらの値を変更できるようにするために追加の変数を作成する必要があるのでしょうか?
 

こんにちは、ひとつだけはっきりさせてください。

例えば、OnTickイベントを使って、条件によってポジションをオープンしたりクローズしたりするEAがあるとします。ストラテジーテスターでは、タイムフレームを設定してEAをテストすることができます。両者がどのようにリンクしているのかがわからない。ストラテジーテスターでテストしたEAは、1ティックごとに反応するのでは?それともStrategy Testerで選択したタイムフレームにのみ反応するのでしょうか?この質問が明確であることを望みます

理由: