Основное правило трейдера - дай прибыли расти, обрезай убытки! В статье рассматривается один из основных технических приемов, позволяющий следовать этому правилу - перемещение уровня защитной остановки (уровня Stoploss) вслед за растущей прибылью позиции, другими словами - скользящий стоп или трейлинг стоп (trailingstop). Приводится пошаговая процедура создания класса для трейлинг стопа на индикаторах SAR и NRTR, который каждый желающий сможет за 5 минут встроить в своего эксперта или использовать независимо для управления позициями на своем счете.
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());
}
}
请告诉我,为什么在策略测试器中 我不设置止损和盈利,而只按市场价格开仓?
我正在使用 CTrade(trade.Buy)建仓。
我试着用(trade.PositionOpen)打开它,结果是一样的,它打开后把止损放在了Demo上,在策略测试器中止损是0,我不知道可能是什么问题。
我明白,我可以手动操作,但我需要一个机器人来做这件事。
我如何创建一个函数来修改订单?
https://www.mql5.com/ru/articles/134
你好,你能告诉我,对于一个EA来说,最低存款1000&(美元账户)或1000卢布(卢布账户)是否有区别?
已经在最后一步灰心了,从现成的战略。不能平均交易,通过
试图进行平均交易。但在参数方面。
我无法确定开盘价,因为我得到的是开盘价,而我想要的是因平均数而发生偏移的价格。
或者只是通过订单历史 查出第一个和第二个订单的价格,并已经在这些数据的基础上进行了平均化,我不想要这种方式,它对我来说太复杂了!
已经在最后一步灰心了,从现成的策略。不能平均交易,通过
我想做个平均交易。但在参数方面。
我无法确定开盘价,因为我得到的是开盘价,而我想要的是因平均数而发生偏移的价格。
或者只是通过订单历史 查出第一个和第二个订单的价格,并已经在这些数据的基础上进行了平均化,我不想要这种方式,它对我来说太复杂了!
你好,请澄清一件事。
例如,我们有一个带有OnTick事件的EA,它将根据条件打开或关闭一个头寸。你可以在策略测试器中测试该EA,在那里你可以设置时间框架。我看不出它们之间有什么相互联系。该EA 不是在策略测试器中进行了测试,而且对每一个tick都有反应吗?或者它只对策略测试器中选定的时间框架做出反应?我希望这个问题是清楚的