EA设计零起点!点点鼠标就能…

EA的基本框架

  1. /+------------------------------------------------------------------+
  2. //|                           Designed by bull, China                |
  3. //|                   Copyright 2007, bull                         |
  4. //|                                 bbs.520fx.com                         |
  5. //+------------------------------------------------------------------+
  6. #property  copyright "Copyright 2007 , bull, China."
  7. #property  link      "bbs.520fx.com"
  8. #define MAGICMA
  9. //+------------------------------------------------------------------+
  10. //| 注意没有指标文件那些property                   |
  11. //+------------------------------------------------------------------+
  12. extern int whichmethod = 1;   //1~4 种下单方式  1 仅开仓, 2 有止损无止赢, 3 有止赢无止损, 4 有止赢也有止损
  13. extern double TakeProfit = 100;   //止赢点数
  14. extern   double StopLoss = 20;    //止损点数
  15. extern double MaximumRisk     = 0.3; //资金控制,控制下单量
  16. extern double TrailingStop =25;     //跟踪止赢点数设置
  17. extern   int maxOpen = 3;   //最多开仓次数限制
  18. extern   int maxLots = 5;   //最多单仓持仓量限制
  19. extern int bb = 0;       //非零就允许跟踪止赢
  20. extern double MATrendPeriod=26;//使用26均线 开仓条件参数  本例子

  21. int i, p2, xxx,p1, res;
  22. double Lots;
  23. datetime lasttime;       //时间控制, 仅当一个时间周期完成才检查条件
  24. int init()   //初始化
  25. {
  26. Lots = 1;
  27. lasttime = NULL;
  28. return(0);
  29. }
  30. int deinit() { return(0); } //反初始化
  31. //主程序
  32. int start()
  33. {
  34. CheckForOpen();    //开仓 平仓 条件检查 和操作
  35. if (bb>0)   CTP();   //跟踪止赢
  36. return(0);
  37. }
  38. //+------下面是各子程序--------------------------------------------+
  39. double LotsOptimized()   //确定下单量,开仓调用 资金控制
  40. {
  41. double lot=Lots;
  42. int   orders=HistoryTotal();   // history orders total
  43. int   losses=0;             // number of losses orders without a break
  44. //MarketInfo(Symbol(),MODE_MINLOT);     相关信息
  45. //MarketInfo(Symbol(),MODE_MAXLOT);
  46. //MarketInfo(Symbol(),MODE_LOTSTEP);
  47. lot=NormalizeDouble(MaximumRisk * AccountBalance()/AccountLeverage(),1);     //开仓量计算
  48. if(lot<0.1) lot=0.1;
  49. if(lot>maxLots) lot=maxLots;
  50. return(lot);
  51. }
  52.   
  53. //平仓持有的买单
  54. void CloseBuy()
  55. {
  56. if (OrdersTotal( ) > 0 )   
  57. {
  58.   for(i=OrdersTotal()-1;i>=0;i--)
  59.   {
  60.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
  61.   if(OrderType()==OP_BUY)
  62.   {
  63.     OrderClose(OrderTicket(),OrderLots(),Bid,3,White);
  64.     Sleep(5000);
  65.   }
  66.   }
  67. }
  68. }
  69. //平仓持有的卖单
  70. void CloseSell()
  71. {
  72. if (OrdersTotal( ) > 0 )   
  73. {
  74.   for(i=OrdersTotal()-1;i>=0;i--)
  75.   {
  76.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
  77.   if(OrderType()==OP_SELL)
  78.     {
  79.     OrderClose(OrderTicket(),OrderLots(),Ask,3,White);
  80.     Sleep(5000);
  81.     }
  82.   }
  83. }
  84. }
  85. //判断是否买或卖或平仓
  86. int buyorsell()   //在这个函数计算设置你的交易信号  这里使用MACD 和MA 做例子
  87. {
  88.   double MacdCurrent, MacdPrevious, SignalCurrent;
  89.   double SignalPrevious, MaCurrent, MaPrevious;
  90.   MacdCurrent=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,0);
  91.   MacdPrevious=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,1);
  92.   SignalCurrent=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,0);
  93.   SignalPrevious=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,1);
  94.   MaCurrent=iMA(NULL,0,MATrendPeriod,0,MODE_EMA,PRICE_CLOSE,0);
  95.   MaPrevious=iMA(NULL,0,MATrendPeriod,0,MODE_EMA,PRICE_CLOSE,1);
  96. if(MacdCurrent<0 && MacdCurrent>SignalCurrent && MacdPrevious<SignalPrevious
  97.     && MaCurrent>MaPrevious)
  98.   return (1); // 买 Ma在上升,Macd在0线上,并且两线上交叉
  99. if(MacdCurrent>0 && MacdCurrent<SignalCurrent && MacdPrevious>SignalPrevious
  100.     && MaCurrent<MaPrevious)
  101.   return (-1); // 卖
  102. return (0); //不交易
  103. }
  104. int nowbuyorsell = 0;
  105. void CheckForOpen()
  106. {
  107. if (Time[0] == lasttime ) return; //每时间周期检查一次  时间控制
  108. lasttime = Time[0];
  109. nowbuyorsell = buyorsell(); //获取买卖信号

  110. if (nowbuyorsell == 1) //买 先结束已卖的
  111.   CloseSell();
  112. if (nowbuyorsell == -1) //卖 先结束已买的
  113.     CloseBuy();
  114. if (TimeDayOfWeek(CurTime()) == 1)
  115.   {
  116.   if (TimeHour(CurTime()) < 3 ) return; //周一早8点前不做 具体决定于你的时区和服务器的时区  时间控制
  117.   }
  118. if (TimeDayOfWeek(CurTime()) == 5)
  119.   {
  120.   if (TimeHour(CurTime()) > 19 ) return; //周五晚11点后不做
  121.   }

  122. if (OrdersTotal( ) >= maxOpen) return ;   
  123. //如果已持有开仓次数达到最大,不做
  124. if (nowbuyorsell==0) return;   //不交易
  125. TradeOK();   //去下单交易
  126. }
  127. void TradeOK()   //去下单交易
  128. {
  129. int error ;
  130. if (nowbuyorsell == 1) //买
  131.   {
  132.     switch (whichmethod)
  133.     {
  134.     case 1:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,0,"",MAGICMA,0,Blue);break;
  135.     case 2:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,Ask-StopLoss*Point,0,"",MAGICMA,0,Blue); break;
  136.     case 3:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,Ask+TakeProfit*Point,"",MAGICMA,0,Blue);break;
  137.     case 4:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,Ask-StopLoss*Point,Ask+TakeProfit*Point,"",MAGICMA,0,Blue);break;
  138.     default : res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,0,"",MAGICMA,0,Blue);break;
  139.     }
  140.     if (res <=0)
  141.     {
  142.     error=GetLastError();
  143.     if(error==134)Print("Received 134 Error after OrderSend() !! ");         // not enough money
  144.     if(error==135) RefreshRates();   // prices have changed
  145.     }
  146.     Sleep(5000);
  147.     return ;   
  148.   }
  149. if (nowbuyorsell == -1) //卖
  150.   {
  151.     switch (whichmethod)
  152.     {
  153.     case 1:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,0,"",MAGICMA,0,Red); break;
  154.     case 2:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,Bid+StopLoss*Point,0,"",MAGICMA,0,Red); break;
  155.     case 3:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,Bid-TakeProfit*Point,"",MAGICMA,0,Red); break;
  156.     case 4:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,Bid+StopLoss*Point,Bid-TakeProfit*Point,"",MAGICMA,0,Red); break;
  157.     default : res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,0,"",MAGICMA,0,Red); break;
  158.     }
  159.     if (res <=0)
  160.     {
  161.     error=GetLastError();
  162.     if(error==134) Print("Received 134 Error after OrderSend() !! ");         // not enough money
  163.     if(error==135) RefreshRates();   // prices have changed
  164.     }
  165.     Sleep(5000);
  166.     return ;   
  167.   }
  168. }
  169. void CTP()   //跟踪止赢
  170. {
  171. bool bs = false;
  172. for (int i = 0; i < OrdersTotal(); i++)
  173. {
  174.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
  175.   if (OrderType() == OP_BUY)
  176.   {
  177.     if ((Bid - OrderOpenPrice()) > (TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT)))    //开仓价格 当前止损和当前价格比较判断是否要修改跟踪止赢设置
  178.     {
  179.     if (OrderStopLoss() < Bid - TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT))
  180.     {
  181.       bs = OrderModify(OrderTicket(), OrderOpenPrice(), Bid - TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT), OrderTakeProfit(),0, Green);
  182.     }
  183.     }
  184.   }
  185.   else if (OrderType() == OP_SELL)
  186.   {
  187.     if ((OrderOpenPrice() - Ask) > (TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT)))  //开仓价格 当前止损和当前价格比较判断是否要修改跟踪止赢设置

  188.     {
  189.     if ((OrderStopLoss()) > (Ask + TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT)))
  190.        
  191.       bs = OrderModify(OrderTicket(), OrderOpenPrice(),
  192.         Ask + TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT), OrderTakeProfit(),0, Tan);
  193. }
  194.     }
  195.   }
  196. }
  197. }
复制代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值