Любые вопросы новичков по MQL4 и MQL5, помощь и обсуждение по алгоритмам и кодам - страница 950

 
Rustam Bikbulatov:

Эта функция пишет на каждом ордере число а точнее лот*100.

Нужна теперь функция обратная которая показывает какое число было в последний раз

Попробуйте это:

double value = StringToDouble(ObjectGetString(0,object_name,OBJPROP_TEXT)); 

Если в объекте есть текст(не числовой), добавить нужно StringSubstr():

double value = StringToDouble( StringSubstr(ObjectGetString(0,object_name,OBJPROP_TEXT),begin_index,length));

begin_index - индекс символа в строке , начиная с нуля, length - длинна числового значения (сколько символов занимает число)... по-моему так

 
Yevhenii Levchenko:

Попробуйте это:

Если в объекте есть текст(не числовой), добавить нужно StringSubstr():

begin_index - индекс символа в строке , начиная с нуля, length - длинна числового значения (сколько символов занимает число)... по-моему так

Ну изначально же надо бы искать эти все номера на графике. Так просто не будет работать. В этом и проблема.  Уже проверил

 
Yevhenii Levchenko:

Попробуйте это:

Если в объекте есть текст(не числовой), добавить нужно StringSubstr():

begin_index - индекс символа в строке , начиная с нуля, length - длинна числового значения (сколько символов занимает число)... по-моему так

   bool name;
        for(int i=0; i<ObjectsTotal(0,"LOTB"+OrderTicket(),OBJ_TEXT); i++)
     {
      name = ObjectSetString(0,"LOTB"+OrderTicket(),OBJ_TEXT,0);
      Comment("   ",name); 
   }

Наподобие этой сделал но не катит. показывает ноль.

 
Rustam Bikbulatov:

Наподобие этой сделал но не катит. показывает ноль.

Вам нужно установить значение или взять? Функция ObjectSetString() устанавливает текстовое значение, а возвращает bool значение. Это не то. И в голове цикла по-моему не верно оформлено...  Там где ObjectsTotal()... Я ориентируюсь по мт4 справочнику. Или это мт5 код?

 
Yevhenii Levchenko:

Вам нужно установить значение или взять? Функция ObjectSetString() устанавливает текстовое значение, а возвращает bool значение. Это не то. И в голове цикла по-моему не верно оформлено...  Там где ObjectsTotal()... Я ориентируюсь по мт4 справочнику. Или это мт5 код?

Это МТ4

 

Ещё раз, всем доброго дня!

Никто не откликнулся на вопрос, заданный мною ранее, но все-равно прошу помочь разобраться с кодом.

Форум по трейдингу, автоматическим торговым системам и тестированию торговых стратегий

Любые вопросы новичков по MQL4 и MQL5, помощь и обсуждение по алгоритмам и кодам

MrBrooklin, 2019.08.30 14:15

Всем доброго дня!

Вот часть кода скрипта для Metatrader5:

#property copyright "Copyright 2019, MetaQuotes Software Corp."
#property link      "https://www.mql5.com"
#property version   "1.00"
//---- показывать входные параметры
#property script_show_inputs
//---
#include <Trade\Trade.mqh>
#include <Trade\SymbolInfo.mqh>
CTrade         m_trade;                      // trading object
CSymbolInfo    m_symbol;                     // symbol info object
//+------------------------------------------------------------------+
//| Enum Stop or Limit                                               |
//+------------------------------------------------------------------+
enum ENUM_STOP_OR_LIMIT
  {
   stop=0,     // Buy stop and Sell stop
   limit=1     // Buy limit and Sell limit
  };
//--- input parameters
input ushort               InpUpGap          = 15;    // Gap for pending orders UP from the current price (in points)
input ushort               InpUpStep         = 30;    // Step between orders UP (in points)

input ushort               InpDownGap        = 15;    // Gap for pending orders DOWN from the current price (in points)
input ushort               InpDownStep       = 30;    // Step between orders DOWN (in points)

input ENUM_STOP_OR_LIMIT   InpPending        = stop;  // Type of pending orders

input uchar                InpUpQuantity     = 1;     // UP quantity orders
input uchar                InpDownQuantity   = 1;     // DOWN quantity orders

input double               InpLots           = 0.01;  // Lots
input ushort               InpStopLoss       = 50;    // Stop Loss (in points)
input ushort               InpTakeProfit     = 50;    // Take Profit (in points)
//---
ulong                      m_slippage=30;             // slippage

double                     ExtUpGap=0.0;
double                     ExtUpStep=0.0;

double                     ExtDownGap=0.0;
double                     ExtDownStep=0.0;

double                     ExtStopLoss=0.0;
double                     ExtTakeProfit=0.0;
//+------------------------------------------------------------------+
//| Script program start function                                    |
//+------------------------------------------------------------------+
void OnStart()
  {
//---
   if(InpLots<=0.0)
     {
      Print("The \"Lots\" can't be smaller or equal to zero");
      return;
     }
//---
   if(!m_symbol.Name(Symbol())) // sets symbol name
      return;
   if(!RefreshRates())
      return;

   string err_text="";
   if(!CheckVolumeValue(InpLots,err_text))
     {
      Print(err_text);
      return;
     }

//---
   if(IsFillingTypeAllowed(SYMBOL_FILLING_FOK))
      m_trade.SetTypeFilling(ORDER_FILLING_FOK);
   else
      if(IsFillingTypeAllowed(SYMBOL_FILLING_IOC))
         m_trade.SetTypeFilling(ORDER_FILLING_IOC);
      else
         m_trade.SetTypeFilling(ORDER_FILLING_RETURN);

//---
   m_trade.SetDeviationInPoints(m_slippage);
   m_trade.SetAsyncMode(true);

//---
   ExtUpGap = m_symbol.Point() * InpUpGap;
   ExtUpStep = m_symbol.Point() * InpUpStep;

   ExtDownGap = m_symbol.Point() * InpDownGap;
   ExtDownStep = m_symbol.Point() * InpDownStep;

   ExtStopLoss = m_symbol.Point() * InpStopLoss;
   ExtTakeProfit = m_symbol.Point() * InpTakeProfit;

//--- start work
   double start_price_ask=m_symbol.Ask()-ExtUpGap;
   double start_price_bid=m_symbol.Bid()+ExtDownGap;

//--- set pending orders
   for(int i=0; i<InpUpQuantity; i++)
     {
      double price_ask = start_price_ask+i*ExtUpStep;
      double price_bid = start_price_bid+i*ExtUpStep;
      if(InpPending==stop)
        {
         double sl = (ExtStopLoss==0.0)   ? 0.0 : price_ask - ExtStopLoss;
         double tp = (ExtTakeProfit==0.0) ? 0.0 : price_ask + ExtTakeProfit;
         m_trade.BuyStop(InpLots,m_symbol.NormalizePrice(price_ask),m_symbol.Name(),
         m_symbol.NormalizePrice(sl),
         m_symbol.NormalizePrice(tp));
        }
      else
        {
         double sl = (ExtStopLoss==0.0)   ? 0.0 : price_bid + ExtStopLoss;
         double tp = (ExtTakeProfit==0.0) ? 0.0 : price_bid - ExtTakeProfit;
         m_trade.SellLimit(InpLots,m_symbol.NormalizePrice(price_bid),m_symbol.Name(),
         m_symbol.NormalizePrice(sl),
         m_symbol.NormalizePrice(tp));
        }
     }

   for(int i=0; i<InpDownQuantity; i++)
     {
      double price_ask = start_price_ask-i*ExtDownStep;
      double price_bid = start_price_bid-i*ExtDownStep;
      if(InpPending==limit)
        {
         double sl = (ExtStopLoss==0.0)   ? 0.0 : price_ask - ExtStopLoss;
         double tp = (ExtTakeProfit==0.0) ? 0.0 : price_ask + ExtTakeProfit;
         m_trade.BuyLimit(m_symbol.LotsMin(),m_symbol.NormalizePrice(price_ask),m_symbol.Name(),
         m_symbol.NormalizePrice(sl),
         m_symbol.NormalizePrice(tp));
        }
      else
        {
         double sl = (ExtStopLoss==0.0)   ? 0.0 : price_bid + ExtStopLoss;
         double tp = (ExtTakeProfit==0.0) ? 0.0 : price_bid - ExtTakeProfit;
         m_trade.SellStop(m_symbol.LotsMin(),m_symbol.NormalizePrice(price_bid),m_symbol.Name(),
         m_symbol.NormalizePrice(sl),
         m_symbol.NormalizePrice(tp));
        }
     }
  }

По задумке скрипт должен устанавливать либо отложенные лимитные ордера на определенном расстоянии от ask и bid, либо стоповые. Лимитные отложенные ордера устанавливаются без проблем, а стоповые нет. Помогите разобраться, почему не устанавливаются отложенные ордера Buy Stop и Sell Stop.

С уважением, Владимир.

Вдогонку ещё один вопрос: есть ли какая-нибудь возможность тестировать скрипт при закрытом рынке (например, в выходные дни)?

С уважением, Владимир.

 
Artyom Trishkin:

Из какого списка?

И, пожалуйста, используйте стилизатор в редакторе (Ctrl+<):

Что откуда нужно взять?

Подскажешь?

 
MrBrooklin:

Ещё раз, всем доброго дня!

Никто не откликнулся на вопрос, заданный мною ранее, но все-равно прошу помочь разобраться с кодом.

Вдогонку ещё один вопрос: есть ли какая-нибудь возможность тестировать скрипт при закрытом рынке (например, в выходные дни)?

С уважением, Владимир.

Нет, скрипт на закрытом рынке не сработает - он не выставит ордеры.

Чтобы разобраться в ошибках, попробуйте распечатать в журнал значение цены, относительно которой рассчитываете уровни установки, и значения всех ценовых уровней, которые вы отправляете в торговый приказ.

 
Привет ребята. Сделал написание лота возле открытого ордера.
for(int no1=0; no1<OrdersTotal(); no1++)
  {
   if(OrderSelect(no1,SELECT_BY_POS,MODE_TRADES))
     {
      if(OrderSymbol()==Symbol() && OrderType()== OP_BUY)
        {
         ObjectCreate("LOTB"+OrderTicket(),OBJ_TEXT,0,TimeCurrent(),OrderOpenPrice());
         ObjectSetText("LOTB"+OrderTicket(),OrderLots()*100,20,"Arial",clrWheat);
         ObjectSetInteger(0,"LOTB"+OrderTicket(),OBJPROP_ANCHOR,ANCHOR_RIGHT_UPPER);
        }
     }
  } 
Подскажите как взять последний текст из этого списка в другой части кода?
 
Rustam Bikbulatov:

Подскажешь?

Вам нужно найти последний ордер, который был открыт. Узнать его тикет. Далее по списку имён объектов ищем вхождение подстроки с найденным тикетом последнего ордера в строке с именем объекта. Как только найдёте в имени объекта тикет последнего ордера - это нужный графический объект. Осталось извлечь из этого графического объекта то, что нужно.

Причина обращения: