Перед тем, мы приступим к рассмотрению торговых функций для открытия/закрытия позиции или управления ордерами, хотелось бы рассказать о двух функциях: OrderExpiration() и OrderMagicNumber().
В данной статье будет рассказано о торговой функции OrderExpiration().
datetime OrderExpiration()
Эта функция возвращает дату эксперации (истечения) отложенного ордера. Если до указанного времени ордер не сработал, то он автоматически удаляется из системы. Ордер должен быть предварительно выбран с помощью функции OrderSelect().
Если дата истечения не установлена (т. е. ордер может существовать бесконечное время, пока не исполнится или не будет удален), то OrderExpiration() вернет 0.
Для чего используется дата истечения отложенного ордера? Причин может быть множество. Например, довольно разумно удалять отложенные ордера в пятницу поздно вечером - перед закрытием недели.
В качестве примера использования функции OrderExpiration() напишем кусок кода, которых пробегает по всем неудаленным отложенным ордерам и если дата истечения не установлена, то устанавливает ее на 23:59:59 ближайшей пятницы.
// вычислим 23:59:59 ближайшей пятницы datetime friday; datetime c_time; c_time = CurTime(); // в friday - дата и время на 00:00:00 текущего дня friday = c_tme-TimeHour(c_time)*60*60-TimeMinute(c_time)*60-TimeSeconds(c_time); // в friday - дата и время на 00:00:00 ближайшей пятницы friday = friday + (5-TimeDayOfWeek(c_time))*60*60*24; // в friday - дата и время на 23:59:59 ближайшей пятницы friday = friday + 23*60*60 + 59*60 + 59; // пробежимся по отложенным ордерам и изменим эксперацию int pos; for(pos=0; posOP_SELL) { // дата эксперации отсутствует? if (OrderExpiration()==0) // изменить дату эксперации OrderModify(OrderTicket(), OrderOpenPrice(), OrderStopLoss(), OrderTakeProfit(), friday); } } else Print("Ошибка ", GetLastError(), " при выборе ордера номер ", pos); }
В этом коде есть несколько неизвестных нам функций:
Например, для 02:16:05 среды функции TimeHour, TimeMinute и TimeSeconds вернут соответственно 2, 16 и 5. А функция TimeDayOfWeek вернет 3.
Мы помним, что значение типа datetime представляет собой количество секунд, прошедшее с 00:00 1 января 1970 года. Также мы помним, что в часе 60*60 секунд, а в минуте 60 секунд. Исходя из этого становится понятной наша логика получения в переменной friday даты и времени, которые соответствуют 23:59:59 ближайшей пятницы:
// вычислим 23:59:59 ближайшей пятницы datetime friday; datetime c_time; c_time = CurTime(); // в friday - дата и время на 00:00:00 текущего дня friday = c_time-TimeHour(c_time)*60*60-TimeMinute(c_time)*60-TimeSeconds(c_time); // в friday - дата и время на 00:00:00 ближайшей пятницы friday = friday + (5-TimeDayOfWeek(c_time))*60*60*24; // в friday - дата и время на 23:59:59 ближайшей пятницы friday = friday + 23*60*60 + 59*60 + 59;
В следующей статье будет рассказано о функции OrderMagicNumber().
Есть что сказать? Не стесняйтесь!
Последние статьи:
Видео по теме:
УГОЛОК АДМИНИСТРАТОРА