Ваши вопросы по языку MQL4

vladradon

Программист
Возможно я чего то не понимаю, но мартин я на сколько знаю работает по другим стратегиям, т.е. собирает по тренду ордера и на коррекции закрывает профит. это не то что мне нужно
Я, как заядлый мартингельщик, хочу пояснить: в моем последнем мартине, который я писал (точнее дорабатывал) больше года, столько функций закрытия, что у меня входных параметров только на среднего сова по строкам.)) И в мартинах можно использовать коэффициенты умножения или прибавления лотов. Или оба сразу и в цифровом или процентном изменения лотности как в сторону увеличения. так и уменьшения. Просто нужно все грамотно прописать в коде.)))
 

vladradon

Программист
Всем привет. Пытаюсь скрипт написать для удаления из истории баров, которые приходятся на воскресенье(автономный график). Сначала, я так понял нужно открыть файл истории FileOpenHistory- и тут вопрос можно ли удалить эти бары из файла или нужно перезаписывать историю с начала уже без этих баров?
Привет. А нужно именно файл истории изменить, который может весить больше мегабайта и его перезаписать, или может проще в коде сова или индикатора заложить исключение расчетов тех данных, которые попадают под исключение - есть же функции возврата времени и дня недели. - Это так... мысли вслух.))
 

Prelagatay

Местный житель
o_oДень добрый товарищи программисты. Попробовал самостоятельно присвоить значения для буфера cтр.225-237, что бы использовать индикатор в советнике, но видать из меня кодер пока никакой. Гляньте пожалуйста чего я там начудил. Сов. не видит индикатор по iCastom.
 

Вложения

  • 10.2 TMA slope v.1.4B 4.30 _3.mq4
    21,3 КБ · Просмотры: 23

vladradon

Программист
День добрый товарищи программисты. Попробовал самостоятельно присвоить значения для буфера cтр.225-237, что бы использовать индикатор в советнике, но видать из меня кодер пока никакой. Гляньте пожалуйста чего я там начудил. Сов. не видит индикатор по iCastom.
Все считывает! Просто нужно правильно прописать iCustom - я прописал в сове тестовом и проверил - все читает. Только еще нужно учесть, что считанные данные нужно проверять на EMPTY_VALUE. Сова прилагаю.
 

Вложения

  • tst.mq4
    2,6 КБ · Просмотры: 22

Артмен

Новичок форума
Добрый день! Помогите пожалуйста исправить предупреждение - "return value of 'OrderModify' should be checked".
void CreateNoLoss()
{
int Orders = OrdersTotal();
for (int i=0; i<Orders; i++)
{
if (!(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))) continue;
if (OrderSymbol() != Symbol()) continue;
{
if (OrderType() == OP_BUY && OrderStopLoss() < OrderOpenPrice())
{
if (Bid-OrderOpenPrice() > MinProfitB*Point)
{
if (OrderStopLoss() < Bid-(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()+NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
if (OrderType() == OP_BUY && OrderStopLoss() == 0)
{
if (Bid-OrderOpenPrice() > MinProfitB*Point)
{
if (OrderStopLoss() < Bid-(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()+NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
if (OrderType() == OP_SELL && OrderStopLoss() > OrderOpenPrice())
{
if (OrderOpenPrice()-Ask > MinProfitB*Point)
{
if (OrderStopLoss() > Ask+(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()-NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
if (OrderType() == OP_SELL && OrderStopLoss() == 0)
{
if (OrderOpenPrice()-Ask > MinProfitB*Point)
{
if (OrderStopLoss() > Ask+(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()-NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
}
}
}
 

mobidik

-----
Добрый день! Помогите пожалуйста исправить предупреждение - "return value of 'OrderModify' should be checked".
void CreateNoLoss()
{
int Orders = OrdersTotal();
for (int i=0; i<Orders; i++)
{
if (!(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))) continue;
if (OrderSymbol() != Symbol()) continue;
{
if (OrderType() == OP_BUY && OrderStopLoss() < OrderOpenPrice())
{
if (Bid-OrderOpenPrice() > MinProfitB*Point)
{
if (OrderStopLoss() < Bid-(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()+NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
if (OrderType() == OP_BUY && OrderStopLoss() == 0)
{
if (Bid-OrderOpenPrice() > MinProfitB*Point)
{
if (OrderStopLoss() < Bid-(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()+NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
if (OrderType() == OP_SELL && OrderStopLoss() > OrderOpenPrice())
{
if (OrderOpenPrice()-Ask > MinProfitB*Point)
{
if (OrderStopLoss() > Ask+(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()-NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
if (OrderType() == OP_SELL && OrderStopLoss() == 0)
{
if (OrderOpenPrice()-Ask > MinProfitB*Point)
{
if (OrderStopLoss() > Ask+(NoLossLevel-1)*Point)
{
OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()-NoLossLevel*Point,OrderTakeProfit(),0,Gold);
}
}
}
}
}
}

Замени строки с модификацией на:
PHP:
if(!OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()-NoLossLevel*Point,OrderTakeProfit(),0,Gold))
 Print("ERROR - ",GetLastError());
или объяви в начале переменную типа bool, например: bool ordermod, а затем измени строку с модификацией на:
PHP:
ordermod = OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()-NoLossLevel*Point,OrderTakeProfit(),0,Gold);
первый вариант предпочтителен, т.к. имеем возможность получить причину ошибки.
 

Renatt

Прохожий
Добрый день!Помогите кто-нибудь добавить в настройки такой вот момент (Previous Indicator"s Data),для совы надо,из кусков собираю,а тут проблема.
 

Renatt

Прохожий
PHP:
//+------------------------------------------------------------------+
//|                                                        Bands.mq4 |
//|                   Copyright 2005-2014, MetaQuotes Software Corp. |
//|                                              mql4.com |
//+------------------------------------------------------------------+
#property copyright   "2005-2014, MetaQuotes Software Corp."
#property link        "mql4.com"
#property description "Bollinger Bands"
#property strict

#include <MovingAverages.mqh>

#property indicator_chart_window
#property indicator_buffers 3
#property indicator_color1 LightSeaGreen
#property indicator_color2 LightSeaGreen
#property indicator_color3 LightSeaGreen
//--- indicator parameters
input int    InpBandsPeriod=20;      // Bands Period
input int    InpBandsShift=0;        // Bands Shift
input double InpBandsDeviations=2.0; // Bands Deviations

//--- buffers
double ExtMovingBuffer[];
double ExtUpperBuffer[];
double ExtLowerBuffer[];
double ExtStdDevBuffer[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit(void)
  {
//--- 1 additional buffer used for counting.
   IndicatorBuffers(4);
   IndicatorDigits(Digits);
//--- middle line
   SetIndexStyle(0,DRAW_LINE);
   SetIndexBuffer(0,ExtMovingBuffer);
   SetIndexShift(0,InpBandsShift);
   SetIndexLabel(0,"Bands SMA");
//--- upper band
   SetIndexStyle(1,DRAW_LINE);
   SetIndexBuffer(1,ExtUpperBuffer);
   SetIndexShift(1,InpBandsShift);
   SetIndexLabel(1,"Bands Upper");
//--- lower band
   SetIndexStyle(2,DRAW_LINE);
   SetIndexBuffer(2,ExtLowerBuffer);
   SetIndexShift(2,InpBandsShift);
   SetIndexLabel(2,"Bands Lower");
//--- work buffer
   SetIndexBuffer(3,ExtStdDevBuffer);
//--- check for input parameter
   if(InpBandsPeriod<=0)
     {
      Print("Wrong input parameter Bands Period=",InpBandsPeriod);
      return(INIT_FAILED);
     }
//---
   SetIndexDrawBegin(0,InpBandsPeriod+InpBandsShift);
   SetIndexDrawBegin(1,InpBandsPeriod+InpBandsShift);
   SetIndexDrawBegin(2,InpBandsPeriod+InpBandsShift);
//--- initialization done
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Bollinger Bands                                                  |
//+------------------------------------------------------------------+
int OnCalculate(const int rates_total,
                const int prev_calculated,
                const datetime &time[],
                const double &open[],
                const double &high[],
                const double &low[],
                const double &close[],
                const long &tick_volume[],
                const long &volume[],
                const int &spread[])
  {
   int i,pos;
//---
   if(rates_total<=InpBandsPeriod || InpBandsPeriod<=0)
      return(0);
//--- counting from 0 to rates_total
   ArraySetAsSeries(ExtMovingBuffer,false);
   ArraySetAsSeries(ExtUpperBuffer,false);
   ArraySetAsSeries(ExtLowerBuffer,false);
   ArraySetAsSeries(ExtStdDevBuffer,false);
   ArraySetAsSeries(close,false);
//--- initial zero
   if(prev_calculated<1)
     {
      for(i=0; i<InpBandsPeriod; i++)
        {
         ExtMovingBuffer[i]=EMPTY_VALUE;
         ExtUpperBuffer[i]=EMPTY_VALUE;
         ExtLowerBuffer[i]=EMPTY_VALUE;
        }
     }
//--- starting calculation
   if(prev_calculated>1)
      pos=prev_calculated-1;
   else
      pos=0;
//--- main cycle
   for(i=pos; i<rates_total && !IsStopped(); i++)
     {
      //--- middle line
      ExtMovingBuffer[i]=SimpleMA(i,InpBandsPeriod,close);
      //--- calculate and write down StdDev
      ExtStdDevBuffer[i]=StdDev_Func(i,close,ExtMovingBuffer,InpBandsPeriod);
      //--- upper line
      ExtUpperBuffer[i]=ExtMovingBuffer[i]+InpBandsDeviations*ExtStdDevBuffer[i];
      //--- lower line
      ExtLowerBuffer[i]=ExtMovingBuffer[i]-InpBandsDeviations*ExtStdDevBuffer[i];
      //---
     }
//---- OnCalculate done. Return new prev_calculated.
   return(rates_total);
  }
//+------------------------------------------------------------------+
//| Calculate Standard Deviation                                     |
//+------------------------------------------------------------------+
double StdDev_Func(int position,const double &price[],const double &MAprice[],int period)
  {
//--- variables
   double StdDev_dTmp=0.0;
//--- check for position
   if(position>=period)
     {
      //--- calcualte StdDev
      for(int i=0; i<period; i++)
         StdDev_dTmp+=MathPow(price[position-i]-MAprice[position],2);
      StdDev_dTmp=MathSqrt(StdDev_dTmp/period);
     }
//--- return calculated value
   return(StdDev_dTmp);
  }
//+------------------------------------------------------------------+
 
Последнее редактирование модератором:

Flank

Новичок форума
Всем привет. Помогите пожалуйста, в этом коде использована немного модифицированная функция приведенная выше, которая возвращала профит последнего закрытого ордера, сейчас она возвращает тикет, так вот, в случае поиска последнего закрытого селл ордера данные не поступают, т.е если я комментирую блок if(lotB/Multiplier == HlotS), то функция NewOrder возвращает ошибку из за отсутствия данных SL, TP и OpPrice (HopS,HotpS,HoslS). Логику специально отключал, чтобы проверить, что возвращает функция NewOrder. Но в это же время касаясь последнего закрытого бай ордера работает всё четко. Не пойму в чем проблема, помогите, если не в тягость.

PHP:
      if(oBuy==1 && oSell==0 && sBuy==0 && sSell==0)
           {
            RetBuy = OrderSelect(RetBuy(),SELECT_BY_POS,MODE_TRADES);             
               lotB=OrderLots();
               
                      bool HistSell = OrderSelect(CloseLastPosTicket(Symbol(), OP_SELL, Magic),SELECT_BY_POS,MODE_HISTORY);
                      double HopS=OrderOpenPrice();
                      double HlotS=OrderLots();
                      double HotpS=OrderTakeProfit();
                      double HoslS=OrderStopLoss();
                        if(lotB/Multiplier == HlotS) 
                           NewOrder(OP_SELLSTOP,lotB*Multiplier,HopS,HotpS,HoslS);

           }
           
      if(oBuy==0 && oSell==1 && sBuy==0 && sSell==0)
           {
            RetSell = OrderSelect(RetSell(),SELECT_BY_POS,MODE_TRADES);           
               lotS=OrderLots();
               
                      bool HistBuy = OrderSelect(CloseLastPosTicket(Symbol(), OP_BUY, Magic),SELECT_BY_POS,MODE_HISTORY);
                      double HopB=OrderOpenPrice();
                      double HlotB=OrderLots();
                      double HotpB=OrderTakeProfit();
                      double HoslB=OrderStopLoss();
                        if(lotS/Multiplier == HlotB) 
                           NewOrder(OP_BUYSTOP,lotS*Multiplier,HopB,HotpB,HoslB);
                  

           }   
}
Собственно сама функция:

PHP:
int CloseLastPosTicket(string sy,int op,int mn)
  {
   datetime t=0;
   int      ticket;
   int      i,k=OrdersHistoryTotal();
 
   if(sy=="0") sy=Symbol();
   for(i=0; i<k; i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY))
        {
         if(OrderSymbol()==sy) // || sy=="")
           {
            if(OrderType()==OP_BUY || OrderType()==OP_SELL)
              {
               if(op<0 || OrderType()==op)
                 {
                  if(mn<0 || OrderMagicNumber()==mn)
                    {
                     if(t<OrderCloseTime())
                       {
                        t=OrderCloseTime();
                        ticket=OrderTicket();
                       }
                    }
                 }
              }
           }
        }
     }
    return(ticket);
  }

Что еще я заметил, когда открытый ордер селл закрылся по стопу, на графике есть характерная линия, а в журнале нет информации о закрытии, а сразу идут ошибки функции NewOrder, в случае с бай позициями всё отлично, и в журнале появляется запись о закрытии по стопу и логика сравнения лотв отрабатывает и открывается отложка.
 
Последнее редактирование:

vladradon

Программист
Помогите пожалуйста
Привет! Для начала у тебя идет выборка по позиции в строках
PHP:
 bool HistBuy = OrderSelect(CloseLastPosTicket(Symbol(), OP_BUY, Magic),SELECT_BY_POS,MODE_HISTORY);
а ты вместо позиции тикет вставляешь. Здесь нужно либо по тикету выбирать SELECT_BY_TICKET, либо задавать цикл выборки по позиции в истории и в цикле сравнивать тикет выбранного в цикле ордера с возвращенным функцией, чтобы считать нужные данные. Но я бы в самой функции, возвращающей тикет, это сделал.
 
Последнее редактирование:

Flank

Новичок форума
Спасибо, в этом я уже разобрался. Но если не сложно поправьте функцию, я не до конца понимаю как это сделать. У меня сейчас другой затык, сов заработал, но открывает позы даже после разрешенного времени, не соображу как исправить.
 

Flank

Новичок форума
Коллеги, помогите пожалуйста с функцией, мне нужно чтобы она возвращала количество закрытых ордеров в день торговли. Может я что то не так сделал, возвращает 0

PHP:
int ClosePosLastTime(string sy,int mn)
  {
   datetime t=TimeDay(TimeCurrent());
   int      i,k=OrdersHistoryTotal();
   int      counter=0;
 
   if(sy=="0") sy=Symbol();
   for(i=0; i<k; i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY))
        {
         if(OrderSymbol()==sy)
           {
            if(OrderType()==OP_BUY || OrderType()==OP_SELL)
              {
               if(mn<0 || OrderMagicNumber()==mn)
                 {
                  if(t==TimeDay(OrderCloseTime()))
                    {
                        counter++;
                    }
                  }
               }
            }
         }
      }
    return(counter); 
  }
 

fs256

Местный знаток
Коллеги, помогите пожалуйста с функцией, мне нужно чтобы она возвращала количество закрытых ордеров в день торговли. Может я что то не так сделал, возвращает 0

PHP:
int ClosePosLastTime(string sy,int mn)
  {
   datetime t=TimeDay(TimeCurrent());
   int      i,k=OrdersHistoryTotal();
   int      counter=0;
 
   if(sy=="0") sy=Symbol();
   for(i=0; i<k; i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY))
        {
         if(OrderSymbol()==sy)
           {
            if(OrderType()==OP_BUY || OrderType()==OP_SELL)
              {
               if(mn<0 || OrderMagicNumber()==mn)
                 {
                  if(t==TimeDay(OrderCloseTime()))
                    {
                        counter++;
                    }
                  }
               }
            }
         }
      }
    return(counter); 
  }

int t=TimeDay(TimeCurrent()); - целое (день месяца).
 

mobidik

-----
Коллеги, помогите пожалуйста с функцией, мне нужно чтобы она возвращала количество закрытых ордеров в день торговли. Может я что то не так сделал, возвращает 0

PHP:
int ClosePosLastTime(string sy,int mn)
  {
   datetime t=TimeDay(TimeCurrent());
   int      i,k=OrdersHistoryTotal();
   int      counter=0;
 
   if(sy=="0") sy=Symbol();
   for(i=0; i<k; i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY))
        {
         if(OrderSymbol()==sy)
           {
            if(OrderType()==OP_BUY || OrderType()==OP_SELL)
              {
               if(mn<0 || OrderMagicNumber()==mn)
                 {
                  if(t==TimeDay(OrderCloseTime()))
                    {
                        counter++;
                    }
                  }
               }
            }
         }
      }
    return(counter); 
  }

У Вас все верно по коду, скорее всего, передаете в саму ф-цию не те параметры, имхо...
Вот, подключил к стандартной сове MACD Sample - считает верно.
 

Вложения

  • MACD_cnt.png
    MACD_cnt.png
    25,6 КБ · Просмотры: 24

Flank

Новичок форума
Грамотно пишешь сообщения, что сейчас редкость. Пожалуй, добавлю в копилку для кнопки "спасибо".

Учился в школе :D, да и на форумах не в первый день. Более того сам был модером и на всякую белиберду иной раз и отвечать не хочется. А я здесь для того, что бы найти помощь и поддержку. Спасибо за отзывчивость!
 

AlexeyVik

Программист mql4 mql5
Коллеги, помогите пожалуйста с функцией, мне нужно чтобы она возвращала количество закрытых ордеров в день торговли. Может я что то не так сделал, возвращает 0

PHP:
int ClosePosLastTime(string sy,int mn)  {   datetime t=TimeDay(TimeCurrent());   int      i,k=OrdersHistoryTotal();   int      counter=0;    if(sy=="0") sy=Symbol();   for(i=0; i<k; i++)     {      if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY))        {         if(OrderSymbol()==sy)           {            if(OrderType()==OP_BUY || OrderType()==OP_SELL)              {               if(mn<0 || OrderMagicNumber()==mn)                 {                  if(t==TimeDay(OrderCloseTime()))                    {                        counter++;                    }                  }               }            }         }      }    return(counter);   }
Я-бы вместо t = TimeDay(TimeCurrent()) использовал t = iTime (_Symbol, PERIOD_D1, 0) или ещё лучше CopyTime(_Symbol, PERIOD_D1, 0, 1, time_array) и выборка ордеров
if(OrderCloseTime() > t) или соответственно if(OrderCloseTime() > time_array[0])

TimeDay() возвращает день месяца и если в истории ордеров открыты ордера за всю историю, то будут выбраны все ордера закрытые в указанное число всех месяцев и всех лет.
А в таком варианте надо запускать отладку и смотреть что на каком этапе получается.
 
Последнее редактирование:
Верх